

# Low Noise, Wide Bandwidth 6D Inertial Measurement Unit with Motion Co-Processor

#### **Features**

- Low 13 mdps/√Hz gyroscope noise, low-latency, and wide bandwidth
- Low Noise 150µg/√Hz accelerometer noise
- Host (slave) interface supports MIPI™ I3C, I<sup>2</sup>C, and 3-wire or 4-wire SPI
- Accelerometer and gyroscope sensors feature signal processing paths with digitally programmable data rates and filtering
- 3-axis gyroscope and 3-axis accelerometer in a small 2.5 x 3.0 x 0.83 mm 14-pin LGA package
- Large 1536-byte FIFO can be used to buffer sensor data to lower system power dissipation
- Integrated Tap, Any-Motion, No-Motion, Significant-Motion detection
- Large sensor dynamic ranges from ±16°/s to ±2048°/s for gyroscope and ±2 g to ±16 g for accelerometer
- Low power modes for effective power management
- Digitally programmable sampling rate and filters
- Embedded temperature sensor
- Wide extended operating temperature range (-40°C to 85°C)

#### **Description**

- The QMI8658A is a complete 6D MEMS inertial measurement unit (IMU). With tight board-level gyroscope sensitivity of ±3%, gyroscope noise density of 13 mdps/√Hz, and low latency, the QMI8658A is ideal for consumer and industrial applications.
- The QMI8658A incorporates a 3-axis gyroscope and a 3-axis accelerometer. It provides a host-processor interface supporting I<sup>3</sup>C, I<sup>2</sup>C and 3-wire or 4-wire SPI.
- With its built-in digital functionality, low power, and small size, the QMI8658A is the ideal part for applications requiring motion-based functionality.

#### **Applications**

- Smartphones
- Game controllers, remote controls and pointing devices
- Robotic vacuums
- E-bikes and scooters
- Bluetooth headsets
- Automotive security systems
- Toy:
- Portrait-landscape display control



#### **Table of Contents**

| 1. | Gen        | eral information                                       | . 5 |
|----|------------|--------------------------------------------------------|-----|
|    | 1.1        | Ordering Information                                   | 5   |
|    | 1.2        | Marking Information                                    | 5   |
|    | 1.3        | Internal Block Diagram                                 | 6   |
|    | 1.4        | Interface Operating                                    |     |
|    | 1.5        | Application Diagrams                                   |     |
|    | 1.6        | Package & Pin Information                              |     |
|    | 1.7        | Shipping packing information                           |     |
|    | 1.8        | Recommended External Components                        |     |
| 2. | QMI        | 8658A Chip Orientation Coordinate System               | 13  |
| 3. | Svs        | tem, Electrical and Electro-Mechanical Characteristics | 14  |
|    | 3.1        | Absolute Maximum Ratings                               |     |
|    | 3.2        | Recommended Operating Conditions                       |     |
|    | 3.3        | Power On Sequence of VDDIO and VDD                     |     |
|    | 3.4        | Electro-Mechanical Specifications                      |     |
|    | 3.5        | Accelerometer Programmable Characteristics             |     |
|    | 3.6        | Gyroscope Programmable Characteristics                 |     |
|    | 3.7        | Electrical Characteristics                             |     |
|    | 3.8        | Current Consumption                                    |     |
|    | 3.9        | Temperature Sensor                                     |     |
|    |            | •                                                      |     |
|    | _          | ister Map Overview                                     |     |
|    | 4.1        | UI Register Map Overview                               | 26  |
| 5. | UI S       | ensor Configuration Settings and Output Data           | 29  |
|    | 5.1        | Typical Sensor Mode Configuration and Output Data      |     |
|    | 5.2        | Chip Information Register                              |     |
|    | 5.3        | Configuration Registers                                |     |
|    | 5.4        | FIFO Registers                                         |     |
|    | 5.5        | Status and Time Stamp Registers                        |     |
|    | 5.6        | Sensor Data Output Registers                           |     |
|    | 5.7        | Calibration-On-Demand (COD) Status Register            |     |
|    | 5.8        | Activity Detection Output Registers                    |     |
|    | 5.9        | Reset Register                                         |     |
|    | 5.10       | CTRL 9 Functionality (Executing Pre-defined Commands)  |     |
| 6  | INITI      | ERRUPTS                                                |     |
| υ. | 6.1        |                                                        |     |
|    | 6.2        | SyncSample mode  Non-SyncSample mode                   |     |
|    | 6.2<br>6.3 | ·                                                      |     |
|    |            | DRDY(Data Ready)                                       |     |
| 7. | Ope        | rating Modes                                           |     |
|    | 7.1        | Operating Modes Descriptions                           | 47  |
|    | 7.2        | General Mode Transitioning                             |     |
|    | 7.3        | Transition Time                                        | 49  |



| 7.4     | Chip Reset Process                         | 49 |
|---------|--------------------------------------------|----|
| 8. FIF  | O Description                              | 50 |
| 8.1     | FIFO Structure                             |    |
| 8.2     | FIFO Size                                  |    |
| 8.3     | Configure FIFO Mode                        |    |
| 8.4     | FIFO Sample Count                          |    |
| 8.5     | FIFO Watermark Interrupt                   |    |
| 8.6     | FIFO Full                                  |    |
| 8.7     | FIFO Read Mode                             |    |
| 8.8     | Read FIFO Data                             |    |
| 8.9     | FIFO Data Pattern                          | _  |
| 8.10    | Reset FIFO                                 |    |
|         |                                            |    |
|         | tion Detection                             |    |
| 9.1     | Motion Detection Principle                 |    |
| 9.2     | Motion Detection Flow                      |    |
| 9.3     | Parameters of Motion Detection             |    |
| 9.4     | Config Motion Detection                    |    |
| 9.5     | Enabling Motion Detection                  |    |
| 9.6     | Motion Interrupt                           | 57 |
| 10. Tap | o                                          | 58 |
| 10.1    | Tap Detection Principle                    |    |
| 10.2    | Tap Detection Parameters                   | 59 |
| 10.3    | Configure Tap                              |    |
| 10.4    | Enable Tap Detection                       | 60 |
| 10.5    | Tap Interrupt                              |    |
| 10.6    | Tap Detection Output                       | 61 |
| 11 1 0  | cking Mechanism                            | 62 |
| 11.1    | Locking Mechanism Principle                |    |
| 11.1    | Locking Mechanism Data Reading Process     |    |
| 11.2    | Data Lock Delay                            |    |
| 11.3    | Exit Locking Mechanism                     |    |
| 11.4    | On-The-Fly ODR Change in Locking Mechanism |    |
|         |                                            |    |
| 12. Cal | libration-On-Demand (COD)                  |    |
| 12.1    | COD Principle                              | 65 |
| 12.2    | Run COD                                    | 65 |
| 12.3    | COD Status                                 |    |
| 12.4    | Save and Restore the New Gain Parameters   | 65 |
| 13. Sel | f-Test (Check-Alive)                       | 66 |
| 13.1    | Accelerometer Self-Test                    |    |
| 13.2    | Gyroscope Self-Test                        |    |
|         | •                                          |    |
|         | st Serial Interface                        |    |
| 14.1    | Address Auto Increment                     |    |
| 14.2    | Serial Peripheral Interface (SPI)          |    |
| 14.3    | I <sup>2</sup> C Interface                 |    |
| 14.4    | I <sup>3</sup> C Interface                 | 76 |



| 15. Pac | ckage and Handling     | 77 |
|---------|------------------------|----|
|         | Package Drawing        |    |
|         | Reflow Specification   |    |
|         | Storage Specifications |    |
|         | gp                     |    |



#### 1. GENERAL INFORMATION

# 1.1 Ordering Information

Table 1. Ordering Information

| Part Number | Package | Packing Method |
|-------------|---------|----------------|
| QMI8658A    | LGA14   | Tape & Reel    |

# 1.2 Marking Information

| ROW | EXAMPLE | CODE/EXPLANATION                                                      |
|-----|---------|-----------------------------------------------------------------------|
| 1   | 8658    | DDDD – Device code                                                    |
| 2   | 2113    | YWLL – Y (Year code), W (1-digit, biweekly code), LL (Lot indication) |
| 3   | • RB    | RB – R (Assembly location), B (Product revision)                      |
|     |         |                                                                       |

Figure 1. Top Mark



#### 1.3 Internal Block Diagram



Figure 2. Internal Block Diagram



#### 1.4 Interface Operating

The QMI8658A can operate in below mode, as shown in the Figure 3.

The QMI8658A is a slave device to a host processor that communicates to it using one of the following interfaces: I<sup>2</sup>C, I<sup>3</sup>C, and SPI (3-wire or 4-wire modes). This slave relationship to the host is the same for all operating modes.



Figure 3. Operating Mode

#### 1.5 Application Diagrams

The typical application diagrams are shown in this section.



Figure 4. 4-Wire SPI-UI mode





Figure 5. 3-Wire SPI-UI mode



Figure 6. I3C/I2C-UI mode

There is internal 200Kohm pull-up resistor on the SCL, SDA, CS, SDx, SCx, RESV (Pin10). By default, all those pull-up resistors are enabled. All the resistors can be disabled by CTRL9 command, refer to 0

#### Package & Pin Information and 5.10.6 CTRL\_CMD\_SET\_RPU for details.0

There is internal 200Kohm pull-up resistor on SDO/SA0 pin, and is enabled during Power-On Reset or Soft-Reset, is automatically disabled after detecting the I2C slave address during the Reset Process. Therefore, in I2C/I3C mode leave the SDO/SA0 float or connect it to High level (recommended, to provide a stable level), will set the I2C slave address/I3C static address to 0x6A. And connect it to Low level, will set the I2C slave address/ I3C static address to 0x6B.

In 3-wire SPI mode, leave the SDO/SA0 pin float.

SCx and SDx can be connected to VDDIO or Logic High, GND or Logic Low, or be left float if internal pull-up resistors are enabled.

RESV (Pin 10) should NOT be connected to GND or Logic Low. It can be connected to VDDIO or Logic High, or leave it externally float and enable the internal pull-up resistor (by default the pull-up resistor is enabled). Connecting it to VDDIO is preferred, which can provide a stable High level.

SCL

SDA



13

14

RESV-NC (Pin 11) is by default an output pin, should be float (no connection). In case of the necessity to connect it to High or Low level, the RESV(Pin 10) should be firmly connected to VDDIO, providing a stable High level, to disable the output of Pin 11.

Table 2 describes the names for the pins in different functions. The later descriptions will directly use the function name in different scenarios instead of the pin name.

| Pin Number | Туре | Pin Name | Function Name in<br>4-wire SPI | Function Name in 3-wire SPI | Function Name in<br>Host I2C / I3C |
|------------|------|----------|--------------------------------|-----------------------------|------------------------------------|
| 1          | 0    | SDO/SA0  | SDO                            |                             | SA0                                |
| 12         | I    | CS       | CS                             | CS                          |                                    |

SPC

SDI

SPC

SDIO

Table 2. Pin Name Mapped to Function Name

#### 1.6 Package & Pin Information

Ю

Ю

SCL

SDA

The pinout of the QMI8658A is shown in Figure 7 and Figure 8. The pin names and functionality are detailed in Table 3. The pin functionality is dictated by the QMI8658A's operating mode, as described in 0

#### Application Diagrams.



Figure 7. Pins Face Down (Top View)

Figure 8. Pins Face Up (Bottom View)



Table 3. Pin Definitions

| Pin<br>Number | Туре | Pin Name                  | Function                                                                                                      |  |
|---------------|------|---------------------------|---------------------------------------------------------------------------------------------------------------|--|
| 1             | 0    | SDO/SA0 <sup>(1)(3)</sup> | SPI-UI Data Out (SDO) in SPI-UI 4-Wire Mode                                                                   |  |
|               |      |                           | SA0, I <sup>2</sup> C Slave address and I <sup>3</sup> C Static address select:                               |  |
|               |      |                           | If SA0 = 0, I <sup>2</sup> C / I <sup>3</sup> C address = 0x6B                                                |  |
|               |      |                           | If SA0 = 1, I <sup>2</sup> C / I <sup>3</sup> C address = 0x6A                                                |  |
| 2             | Ю    | SDx <sup>(1)(2)</sup>     | Reserved. Connect to VDDIO, GND or No Connection                                                              |  |
| 3             | Ю    | SCx <sup>(1)(2)</sup>     | Reserved. Connect to VDDIO, GND or No Connection                                                              |  |
| 4             | 0    | INT1                      | Programmable Interrupt 1                                                                                      |  |
| 5             | I    | VDDIO                     | Power Supply for IO Pins                                                                                      |  |
| 6             | I    | GND                       | Ground (0 V supply)                                                                                           |  |
| 7             | I    | GND                       | Ground (0 V supply)                                                                                           |  |
| 8             | I    | VDD                       | Power supply                                                                                                  |  |
| 9             | 0    | INT2                      | Programmable Interrupt 2 (INT2) / Data Ready (DRDY)                                                           |  |
| 10            | Ю    | RESV <sup>(1)(2)</sup>    | Reserved. Connect to VDDIO or Logic High, or No Connection and enable (by default) internal pull up resistor. |  |
|               |      |                           | Refer to 1.5 Application Diagrams.                                                                            |  |
| 11            | I    | RESV-NC                   | Reserved. Float is preferred.                                                                                 |  |
|               |      |                           | Refer to 1.5 Application Diagrams.                                                                            |  |
| 12            | I    | CS <sup>(1)(2)</sup>      | I <sup>2</sup> C/ I <sup>3</sup> C /SPI-UI selection Pin.                                                     |  |
|               |      |                           | (If 1: I <sup>2</sup> C-UI Mode: I <sup>2</sup> C/I <sup>3</sup> C communication enabled, SPI idle mode)      |  |
|               |      |                           | (If 0: SPI-UI mode: I <sup>2</sup> C/I <sup>3</sup> C disabled)                                               |  |
| 13            | Ю    | SCL <sup>(1)(2)</sup>     | I <sup>2</sup> C/I <sup>3</sup> C-UI Data (SCL) in I <sup>2</sup> C/ I <sup>3</sup> C mode                    |  |
|               |      |                           | SPI-UI Serial Clock (SPC) (3) in SPI mode                                                                     |  |
| 14            | Ю    | SDA <sup>(1)(2)</sup>     | I <sup>2</sup> C/I <sup>3</sup> C-UI Data (SDA)                                                               |  |
|               |      |                           | SPI-UI Data In (SDI) (3) in 4 wire Mode                                                                       |  |
|               |      |                           | SPI-UI Data IO (SDIO) (3) in 3 Wire Mode                                                                      |  |

- 1.
- This pin has an internal  $200 \text{K}\Omega$  pull up resistor. The internal pull-up resistor can be disabled by CTRL9 command (CTRL\_CMD\_SET\_RPU). Refer to 5.10.6 CTRL\_CMD\_SET\_RPU for details. Refer to Section 14 for detailed configuration information. 2.
- 3.



## 1.7 Shipping packing information

Devices are shipped in reels, in standard cardboard box packaging.

| Package    | Reel Size | Carrier tape<br>WidthxPitch | Qty/reel | Pin 1 Location |
|------------|-----------|-----------------------------|----------|----------------|
| LGA(3x2.5) | 13"       | 12*8                        | 3000     | Up Left        |

#### Carrier tape drawing



#### 1.8 Recommended External Components

**Table 4. Recommended External Components** 

| Component                      | Description | Parameter   | Typical     |
|--------------------------------|-------------|-------------|-------------|
| C <sub>p1</sub>                | Capacitor   | Capacitance | 100 nF      |
| C <sub>p2</sub>                | Capacitor   | Capacitance | 100 nF      |
| R <sub>pu</sub> <sup>(4)</sup> | Resistor    | Resistance  | 2ΚΩ ~ 10 kΩ |

#### Note:

4. Rpu resistors are only needed when the Host Serial Interface is configured for I<sup>2</sup>C (see I2C Interface section). They are not needed when the Host Serial Interface is configured for SPI or I<sup>3</sup>C. If pull-up resistors are used on SCL and SDA, then SPI, I<sup>3</sup>C and I<sup>2</sup>C Modes are all possible. If a pull-down resistor is used on SA0, an alternate slave address is used for I<sup>2</sup>C. SPI and I<sup>3</sup>C modes will be unaltered with the use of pull-up resistors for I<sup>2</sup>C. Additionally, a suitable pull up resistance (Rpu) value should be selected, accounting for the tradeoff between current consumption and rise time.







Figure 9. Typical Electrical Connections



#### 2. QMI8658A CHIP ORIENTATION COORDINATE SYSTEM

The QMI8658A uses a right-handed coordinate system as the basis for the sensor frame of reference. Acceleration (ax, ay, az) are given with respect to the X-Y-Z coordinate system shown above. Increasing accelerations along the positive X-Y-Z axes are considered positive. Angular Rate ( $\omega_x$ ,  $\omega_y$ ,  $\omega_z$ ) in the counterclockwise direction around the respective axis are considered positive.

0 shows the various frames of reference and conventions for using the QMI8658A.



Figure 10. Chip Orientation Coordinate System



# 3. SYSTEM, ELECTRICAL AND ELECTRO-MECHANICAL CHARACTERISTICS

#### 3.1 Absolute Maximum Ratings

Stresses exceeding the absolute maximum ratings may damage the device. The device may not function or be operable above the recommended operating conditions. Stressing the parts to these levels is not recommended. In addition, extended exposure to stresses above the recommended operating conditions may affect device reliability. The absolute maximum ratings are stress ratings only.

Table 5. Absolute Maximum Ratings

| Symbol                        |                                                                                                                | Min.              | Max.          | Unit   |    |
|-------------------------------|----------------------------------------------------------------------------------------------------------------|-------------------|---------------|--------|----|
| Tstg                          | Storage Temperature                                                                                            |                   | -40           | +125   | °C |
| T <sub>Pmax</sub>             | Lead Soldering Tempera                                                                                         | ature, 10 Seconds |               | +260   | °C |
| VDD                           | Supply Voltage                                                                                                 | Supply Voltage    |               |        | V  |
| VDDIO                         | I/O Pins Supply Voltage                                                                                        | -0.3              | 3.6           | V      |    |
| S <sub>g</sub> <sup>(5)</sup> | Acceleration g for 0.2 ms                                                                                      | s (Un-powered)    |               | 10,000 | g  |
| FSD <sup>(6)</sup>            | Electrostatic Discharge Protection Level Human Body Model per JES001-2014 Charged Device Model per JESD22-C101 |                   | ±2000<br>±500 |        |    |
| ESD(6)                        |                                                                                                                |                   |               |        | V  |

#### Notes:

- 5. This is a mechanical shock (g) sensitive device. Proper handling is required to prevent damage to the part.
- 5. This is an ESD-sensitive device. Proper handling is required to prevent damage to the part.

#### 3.2 Recommended Operating Conditions

The Recommended Operating Conditions table defines the conditions for device operation. Recommended operating conditions are specified to ensure optimal performance. It is not forbidden to design beyond Absolute Maximum Ratings.

Table 6. Recommended Operating Conditions

| Symbol               | Parameter                         | Min        | Тур | Max         | Unit |
|----------------------|-----------------------------------|------------|-----|-------------|------|
| VDD                  | Supply Voltage                    | 1.71       | 1.8 | 3.6         | ٧    |
| VDDIO                | I/O Pins Supply Voltage           | 1.71       | 1.8 | 3.6         | V    |
| V <sub>IL</sub>      | Digital Low Level Input Voltage   |            |     | 0.3 *VDDIO  | ٧    |
| V <sub>IH</sub>      | Digital High Level Input Voltage  | 0.7 *VDDIO |     | VDDIO + 0.3 | V    |
| VoL                  | Digital Low Level Output Voltage  |            |     | 0.1 *VDDIO  | ٧    |
| V <sub>OH</sub>      | Digital High Level Output Voltage | 0.9 *VDDIO |     |             | V    |
| V <sub>POR_RLS</sub> | POR Threshold Voltage             |            | 1.1 |             | V    |



#### 3.3 Power On Sequence of VDDIO and VDD

#### 3.3.1 Power Off Condition

To make sure the POR block functions well, the constrains on the condition for power off (for both VDD and VDDIO) in Table 7. Refer to Figure 11 and Figure 12 for the illustration.

| Parameter          | Symbol | Condition                                                                                        | Min. | Тур. | Max. | Unit |
|--------------------|--------|--------------------------------------------------------------------------------------------------|------|------|------|------|
| Power Off Voltage  | SDV    | Voltage that Device Considers to be Power Down, valid for VDD & VDDIO.                           |      |      | 0.2  | V    |
| Power Off Interval | PINT   | Time Period Required for Voltage<br>Lower Than SDV to Enable Next<br>POR, valid for VDD & VDDIO. | 100  |      |      | μs   |

Table 7. Power Off Condition

#### 3.3.2 Power-On Reset (POR)

Once the VDD & VDDIO are powered from 0V to a certain level, the internal power voltage detector will trigger the Power-On Reset (POR) automatically, and then exit/release the POR mode as the VDD voltage rises over the POR Threshold (about 1.1V). Refer to *Table 6*.

After POR release, there will be about 200us Startup Delay, followed by the QMI8658A Initialization.

The instability of VDDIO & VDD power lines, especially the power increase/drop with high slew rate, would interfere with the QMI8658A Initialization and operation. Therefore, there should be no sudden transients and spikes on power lines after Startup Delay, to make sure the Initialization and later on operations are properly implemented.

Normally it takes within about 15ms (refer to *System Turn On Time* in *Table 8* and *Table 9*) for QMI8658A to finish the Initialization and during which, there should be no write/configuration to QMI8658A, to prevent possible interference and failure.

Note that the Software Reset is triggered by the reset command that host write to QMI8658A, which means POR is not involved, while the following sequence are similar (Startup Delay and Initialization) to POR. Refer to 7.4 for more details.

#### 3.3.3 VDDIO and VDD Are Driven by Single Power

As shown in *Figure 11*, when QMI8658A is driven by single/same power line, the power line should ramp up from POR Threshold (about 1.1V) to Min Operation Voltage(1.71V) with slew rate higher than 40V/s, otherwise the Initialization might fail, and QMI8658A might not work properly.



Figure 11. Power On Process When Driven by Single Power Line



#### 3.3.4 VDDIO and VDD Are Driven by Separate Power Lines

As shown in Figure 12, when QMI8658A is driven by separate power lines, the VDDIO should be always powered ahead of (no later than) VDD, which means:

VDDdelay >= 0, VDDIO should be driven no later than VDD

Note that the VDDdelay starts from the point when VDDIO rises over the POR Threshold and ends at the VDD rises over the POR Threshold. It should always be non-negative.

The power lines should ramp up from POR Threshold (about 1.1V) to Min Operation Voltage(1.71V) with slew rate higher than 40V/s, otherwise the Initialization might fail, and QMI8658A might not work properly.



Figure 12. Power On Process When Driven by Separate Power Lines



### 3.4 Electro-Mechanical Specifications

VDD = VDDIO = 1.8 V, T = 25°C unless otherwise noted.

Table 8. Accelerometer Electro-Mechanical Specifications

| Subsystem     | Parameter                                         | Турі          | cal         | Unit   | Comments                                                                                           |
|---------------|---------------------------------------------------|---------------|-------------|--------|----------------------------------------------------------------------------------------------------|
|               | Noise Density <sup>(11)</sup>                     | 150           | )           | μg/√Hz | High-Resolution Mode                                                                               |
|               |                                                   | Scale Setting | Sensitivity |        |                                                                                                    |
|               |                                                   | ±2 g          | 16,384      |        |                                                                                                    |
|               | Sensitivity Scale Factor                          | ±4 g          | 8,192       | LSB/g  | 16-Bit Output                                                                                      |
|               |                                                   | ±8 g          | 4,096       |        |                                                                                                    |
|               |                                                   | ±16 g         | 2,048       |        |                                                                                                    |
|               | Cross-Axis Sensitivity <sup>(11)</sup>            | ±1            |             | %      |                                                                                                    |
| Accelerometer | Temperature Coefficient of Offset (TCO) (11)      | ±0.           | 7           | mg/°C  | Over-Temperature Range of -40°C to 85°C, at Board Level                                            |
|               | Temperature Coefficient of Sensitivity (TCS) (11) | ±0.0          | 03          | %/°C   | Over-Temperature Range of -40°C to 85°C, at Board Level                                            |
|               | Initial Offset Tolerance(11)                      | ±10           | 0           | mg     | Board Level                                                                                        |
|               | Initial Sensitivity Tolerance <sup>(11)</sup>     | ±1            |             | %      | Board Level                                                                                        |
|               | Non-Linearity <sup>(11)</sup>                     | ±0.7          | <b>'</b> 5  | %      | Best Fit Line                                                                                      |
|               | System Turn On Time <sup>(7)</sup>                | 15            |             | ms     | From Software Reset, No<br>Power, or Power Down to<br>Power-on Default state = t0 in<br>Figure 16  |
|               | Accel Turn On Time <sup>(8)</sup>                 | 3 ms + 3      | 3/ODR       | ms     | Accel Turn on from Power-On<br>Default state or from Low<br>Power state = t2 + t5 in Figure<br>16. |

- System Turn-On Time defines the initialization duration of QMI8658A, it starts from about 200us later than the release of POR (Power On Reset) or the Software Reset. Refer to 3.3 and 7.4 for details.
- 8. Note that the settling time of the accelerometer data is minimum 3/ODR and will be longer according to different sensor configuration cases for example, when the accelerometer data filter is enabled. For more information, and for application-specific cases please consult the QST FAE team.



Table 9. Gyroscope Electro-Mechanical Specifications

| Subsystem | Parameter                                         | Тур              | ical        | Unit     | Comments                                                                                          |
|-----------|---------------------------------------------------|------------------|-------------|----------|---------------------------------------------------------------------------------------------------|
|           |                                                   | Scale<br>Setting | Sensitivity |          |                                                                                                   |
|           |                                                   | ±16 dps          | 2048        |          |                                                                                                   |
|           |                                                   | ±32 dps          | 1024        |          |                                                                                                   |
|           |                                                   | ±64 dps          | 512         |          |                                                                                                   |
|           | Sensitivity                                       | ±128 dps         | 256         | LSB/dps  | 16-Bit Output                                                                                     |
|           |                                                   | ±256 dps         | 128         |          |                                                                                                   |
|           |                                                   | ±512 dps         | 64          |          |                                                                                                   |
|           |                                                   | ±1024 dps        | 32          |          |                                                                                                   |
|           |                                                   | ±2048 dps        | 16          |          |                                                                                                   |
|           | Natural Frequency                                 | 22.              | 42          | kHz      | Precision +/- 2%(typical)                                                                         |
|           | Noise Density <sup>(11)</sup>                     | 1:               | 3           | mdps/√Hz | High-Resolution Mode                                                                              |
|           | Non-Linearity <sup>(11)</sup>                     | ±0               | .2          | %        |                                                                                                   |
| 0         | Cross-Axis Sensitivity <sup>(11)</sup>            | ±                | 2           | %        |                                                                                                   |
| Gyroscope | g-Sensitivity <sup>(11)</sup>                     | ±0               | .1          | dps/g    |                                                                                                   |
|           | System Turn On Time <sup>(9)</sup>                | 1:               | 5           | ms       | From Software Reset, No<br>Power, or Power Down to<br>Power-on Default state<br>= t0 in Figure 16 |
|           | Gyro Turn On Time <sup>(10)</sup>                 | 150 ms +         | + 3/ODR     | ms       | Gyro Turn on from Power-<br>On Default = t1 + t5 in<br>Figure 16                                  |
|           | Temperature Coefficient of Offset (TCO) (11)      | X/Y: ±<br>Z: ±0  |             | dps/°C   | Over-Temperature Range of -40°C to 85°C, at Board Level                                           |
|           | Temperature Coefficient of Sensitivity (TCS) (11) | X/Y: ±<br>Z: ±0  |             | %/°C     | Over-Temperature Range of -40°C to 85°C, at Board Level                                           |
|           | Initial Offset Tolerance(11)                      | ±1               | 0           | dps      | Board Level                                                                                       |
|           | Initial Sensitivity<br>Tolerance <sup>(11)</sup>  | ±1               | .5          | %        | Board Level                                                                                       |

- 9. System Turn-On Time defines the initialization duration of QMI8658A, it starts from about 200us later than the release of POR (Power On Reset) or the Software Reset. Refer to 3.3 and 7.4 for details.
- 10. Note that the settling time of the gyroscope data is minimum 3/ODR and will be longer according to different sensor configuration cases for example, when the gyroscope data filter is enabled. For more information, and for application-specific cases please consult the QST FAE team.
- 11. Typical values are measured in board-level in characterization only.



#### 3.5 Accelerometer Programmable Characteristics

VDD = VDDIO = 1.8 V, T = 25°C unless otherwise noted. Typical numbers are provided below unless otherwise noted.

If only accelerometer is enabled, the ODR frequency is derived from the internal oscillator. If both accelerometer and gyroscope (6DOF mode) are enabled, the ODR frequency is derived from the natural frequency of gyroscope. *Table 10* shows the two ODR frequencies, which can be referenced for later descriptions in the datasheet. Refer to section *5.3* for detailed ODR configuration.

RMS noise can be calculated based on the noise density and the bandwidth.

**Table 10. Accelerometer Noise Density** 

| Mode                        |        |        |        | High- | Resolu | ition |       |       |        |     | Unit |     |     |        |
|-----------------------------|--------|--------|--------|-------|--------|-------|-------|-------|--------|-----|------|-----|-----|--------|
| ODR<br>(Accel<br>only)      |        |        |        | 1000  | 500    | 250   | 125   | 62.5  | 31.25  | 128 | 21   | 11  | 3   | Hz     |
| ODR<br>(Accel +<br>Gyro)    | 7174.4 | 3587.2 | 1793.6 | 896.8 | 448.4  | 224.2 | 112.1 | 56.05 | 28.025 |     |      |     |     | Hz     |
| Typical<br>Noise<br>Density | 150    | 150    | 150    | 150   | 150    | 150   | 150   | 150   | 150    | 125 | 180  | 285 | 700 | μg/√Hz |

Table 11. Accelerometer Filter Characteristics (Accelerometer only)(12)

| Mode                                                                    |      | High-Resolution |      |       |       |      |      |      |       |      |     | ower | •   | Unit |
|-------------------------------------------------------------------------|------|-----------------|------|-------|-------|------|------|------|-------|------|-----|------|-----|------|
| ODR                                                                     | 8000 | 4000            | 2000 | 1000  | 500   | 250  | 125  | 62.5 | 31.25 | 128  | 21  | 11   | 3   |      |
| Bandwidth<br>(Default, 27.5% of<br>ODR)                                 | NA   | NA              | NA   | 275   | 137.5 | 68.8 | 34.4 | 17.2 | 8.6   | 35.2 | 5.8 | 3.0  | 0.8 |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 00<br>(2.66% of ODR)  | NA   | NA              | NA   | 26.6  | 13.3  | 6.7  | 3.3  | 1.7  | 0.8   | 3.4  | 0.6 | 0.3  | 0.1 |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 01<br>(3.63% of ODR)  | NA   | NA              | NA   | 36.3  | 18.2  | 9.1  | 4.5  | 2.3  | 1.1   | 4.6  | 0.8 | 0.4  | 0.1 | Hz   |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 10<br>(5.39% of ODR)  | NA   | NA              | NA   | 53.9  | 27    | 13.5 | 6.7  | 3.4  | 1.7   | 6.9  | 1.1 | 0.6  | 0.2 |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 11<br>(13.37% of ODR) | NA   | NA              | NA   | 133.7 | 66.9  | 33.4 | 16.7 | 8.4  | 4.2   | 17.1 | 2.8 | 1.5  | 0.4 |      |

<sup>12.</sup> When only accelerometer is enabled, the ODR is derived from the internal oscillator, rather than the nature frequency of Gyroscope.



Table 12. Accelerometer Filter Characteristics  $(6DOF)^{(13)}$ 

| Mode                                                                              |        |        |        | High- | Resolu | tion  |       |       |        | L   | _ow-l | Powe | r  | Unit |
|-----------------------------------------------------------------------------------|--------|--------|--------|-------|--------|-------|-------|-------|--------|-----|-------|------|----|------|
| ODR                                                                               | 7174.4 | 3587.2 | 1793.6 | 896.8 | 448.4  | 224.2 | 112.1 | 56.05 | 28.025 | 128 | 21    | 11   | 3  |      |
| Bandwidth<br>(Default,<br>27.5% of<br>ODR)                                        | 1973.0 | 986.5  | 493.2  | 246.6 | 123.3  | 61.7  | 30.8  | 15.4  | 7.7    | NA  | NA    | NA   | NA |      |
| Bandwidth<br>with Low-<br>Pass Filter<br>Enabled<br>Mode 00<br>(2.66% of<br>ODR)  | 190.8  | 95.4   | 47.7   | 23.9  | 11.9   | 6.0   | 3.0   | 1.5   | 0.7    | NA  | NA    | NA   | NA |      |
| Bandwidth<br>with Low-<br>Pass Filter<br>Enabled<br>Mode 01<br>(3.63% of<br>ODR)  | 260.4  | 130.2  | 65.1   | 32.6  | 16.3   | 8.1   | 4.1   | 2.0   | 1.0    | NA  | NA    | NA   | NA | Hz   |
| Bandwidth<br>with Low-<br>Pass Filter<br>Enabled<br>Mode 10<br>(5.39% of<br>ODR)  | 386.7  | 193.4  | 96.7   | 48.3  | 24.2   | 12.1  | 6.0   | 3.0   | 1.5    | NA  | NA    | NA   | NA |      |
| Bandwidth<br>with Low-<br>Pass Filter<br>Enabled<br>Mode 11<br>(13.37% of<br>ODR) | 959.2  | 479.6  | 239.8  | 119.9 | 60.0   | 30.0  | 15.0  | 7.5   | 3.7    | NA  | NA    | NA   | NA |      |

<sup>13.</sup> When both accelerometer and gyroscope are both enabled, all frequencies are synchronized to the nature frequency of gyroscope.



#### 3.6 Gyroscope Programmable Characteristics

VDD = VDDIO = 1.8 V, T = 25°C, and represent typical numbers unless otherwise noted. All frequencies are synchronized to the gyroscope nature frequency.

0 shows the noise density of gyroscope output over different ODR configurations.

The typical bandwidths of gyroscope over different ODR settings are listed in Table 14.

RMS noise can be calculated based on the noise density and the bandwidth.

Table 13. Gyroscope Noise Density

| Mode                    |                     | High-Resolution     |                     |       |       |       |       |       |        |          |  |  |
|-------------------------|---------------------|---------------------|---------------------|-------|-------|-------|-------|-------|--------|----------|--|--|
| ODR (Gyro and/or Accel) | 7174.4              | 3587.2              | 1793.6              | 896.8 | 448.4 | 224.2 | 112.1 | 56.05 | 28.025 | Hz       |  |  |
| Typical Noise Density   | RSV <sup>(14)</sup> | RSV <sup>(14)</sup> | RSV <sup>(14)</sup> | 13    | 13    | 13    | 13    | 13    | 13     | mdps/√Hz |  |  |

#### Note:

14. The gyroscope noise increases significantly when the ODR is set above 1KHz. It is not recommended to set the ODR beyond 1KHz for the applications that are impacted by gyroscope noise. For more information please contact QST FAE team.

Table 14. Gyroscope Filter Characteristics

| Mode                                                                    |        |        |        | High  | -Resolu | tion  |       |       |        | Unit |
|-------------------------------------------------------------------------|--------|--------|--------|-------|---------|-------|-------|-------|--------|------|
| ODR                                                                     | 7174.4 | 3587.2 | 1793.6 | 896.8 | 448.4   | 224.2 | 112.1 | 56.05 | 28.025 |      |
| Bandwidth<br>(Default, 27.5% of<br>ODR)                                 | 1973.0 | 986.5  | 493.2  | 246.6 | 123.3   | 61.7  | 30.8  | 15.4  | 7.7    |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 00<br>(2.66% of ODR)  | 190.8  | 95.4   | 47.7   | 23.9  | 11.9    | 6.0   | 3.0   | 1.5   | 0.7    |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 01<br>(3.63% of ODR)  | 260.4  | 130.2  | 65.1   | 32.6  | 16.3    | 8.1   | 4.1   | 2.0   | 1.0    | Hz   |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 10<br>(5.39% of ODR)  | 386.7  | 193.4  | 96.7   | 48.3  | 24.2    | 12.1  | 6.0   | 3.0   | 1.5    |      |
| Bandwidth with<br>Low-Pass Filter<br>Enabled Mode 11<br>(13.37% of ODR) | 959.2  | 479.6  | 239.8  | 119.9 | 60.0    | 30.0  | 15.0  | 7.5   | 3.7    |      |



#### 3.7 Electrical Characteristics

VDD = VDDIO = 1.8 V, T = 25°C unless otherwise noted.

**Table 15. Electrical Subsystem Characteristics** 

| Symbol            | Paramet                                                          | er                       | Min. | Тур. | Max. | Unit |
|-------------------|------------------------------------------------------------------|--------------------------|------|------|------|------|
| fspc              | Host SPI Interface Speed                                         |                          |      |      | 15   | MHz  |
| fscL              | Host I <sup>2</sup> C Interface Speed (stand Mode are supported) | ard mode and Fast        |      |      | 400  | kHz  |
| f <sub>SCL3</sub> | Host I <sup>3</sup> C Interface Speed                            | Standard Data Rate (SDR) |      |      | 12.5 | MHz  |



#### 3.8 Current Consumption

VDD = VDDIO = 1.8 V, T = 25°C unless otherwise noted. IDD Current refers to the current flowing into the VDD pin. Typical numbers are provided below.

Table 16. Current Consumption for Accelerometer Only Sensor Mode (Gyroscope Disabled)

|                        | Mode                      |      |     | High-F | Resolut | ion  |       | Low-Power |    |    |    | Unit |
|------------------------|---------------------------|------|-----|--------|---------|------|-------|-----------|----|----|----|------|
|                        | ODR                       | 1000 | 500 | 250    | 125     | 62.5 | 31.25 | 128       | 21 | 11 | 3  | Hz   |
| Typical<br>Overall IDD | Filters Disabled (aLPF=0) | 182  | 155 | 142    | 134     | 133  | 132   | 55        | 42 | 35 | 30 |      |
| Current                | Filters Enabled (aLPF=1)  | 182  | 155 | 142    | 134     | 133  | 132   | 55        | 42 | 35 | 30 | μА   |

Table 17. Current Consumption for Gyroscope Only Sensor Mode (Accelerometer Disabled)

|                    | Mode                      |        | High-Resolution |        |       |       |       |       |       |        |    |  |  |
|--------------------|---------------------------|--------|-----------------|--------|-------|-------|-------|-------|-------|--------|----|--|--|
|                    | ODR                       | 7174.4 | 3587.2          | 1793.6 | 896.8 | 448.4 | 224.2 | 112.1 | 56.05 | 28.025 | Hz |  |  |
| Typical<br>Overall | Filters Disabled (gLPF=0) | 908    | 861             | 748    | 689   | 659   | 656   | 654   | 653   | 651    | μА |  |  |
| IDD<br>Current     | Filters Enabled (gLPF=1)  | 916    | 863             | 748    | 689   | 659   | 656   | 654   | 653   | 651    | μΑ |  |  |

Table 18. Current Consumption for 6DOF Sensor Mode (Accelerometer and Gyroscope Enabled)

| N                      | /lode                                   |        |        |        | High-l | Resolut | ion   |       |       |        | Unit |
|------------------------|-----------------------------------------|--------|--------|--------|--------|---------|-------|-------|-------|--------|------|
|                        | ODR                                     | 7174.4 | 3587.2 | 1793.6 | 896.8  | 448.4   | 224.2 | 112.1 | 56.05 | 28.025 | Hz   |
| Typical                | Filters Disabled<br>(aLPF=0;<br>gLPF=0) | 1004   | 956    | 843    | 786    | 757     | 754   | 752   | 751   | 750    | ^    |
| Overall IDD<br>Current | Filters Enabled<br>(aLPF=1;<br>gLPF=1)  | 1031   | 970    | 850    | 789    | 758     | 756   | 753   | 751   | 750    | μА   |



#### 3.9 Temperature Sensor

The QMI8658A is equipped with an internal 16-bit embedded temperature sensor that is automatically turned on by default whenever the accelerometer or gyroscope is enabled. The temperature sensor is used internally to correct the temperature dependency of calibration parameters of the accelerometer and gyroscope. The temperature compensation is optimal in the range of -40°C to 85°C with a resolution of 0.0625°C (1/16 °C) or inversely, 16 LSB/°C.

The QMI8658A outputs the internal chip temperature that the HOST can read. The output is 16 bits, with a (1/256)°C per LSB resolution. To read the temperature, the HOST needs to access the TEMP register (see TEMP\_L and TEMP\_H in Data Output Registers in Table 26).

The calculation formular is:

$$T = (TEMP_H * 256 + TEMP_L) / 256$$

Note that the TEMP\_H is a signed value, that defines the sign of T. To read the temperature sensor data properly, the Host is expected to follow the guidelines in 0



Locking Mechanism.

#### **Table 19. Temperature Sensor Specifications**

| Subsystem                  | Parameter             | Typical    | Unit   |
|----------------------------|-----------------------|------------|--------|
|                            | Range                 | -40 to +85 | °C     |
|                            | Internal Resolution   | 16         | Bits   |
| Digital Temperature Sensor | Internal Sensitivity  | 256        | LSB/°C |
| Digital Temperature Sensor | Output Register Width | 16         | Bits   |
|                            | Output Sensitivity    | 256        | LSB/°C |
|                            | Refresh Rate          | 8          | Hz     |



#### 4. REGISTER MAP OVERVIEW

The QMI8658A UI registers enable programming and control of the inertial measurement unit and associated on-chip signal processing. These registers are accessed through the UI interface – either SPI (4 wires or 3 wires) I3C, or I<sup>2</sup>C.

#### 4.1 UI Register Map Overview

UI register map may be classified into the following register categories:

- (1) Chip Information Registers
- (2) Setup and Control Registers: control various aspects of the IMU
- (3) Host Controlled Calibration Registers: control and configure various aspects of the IMU via the host command interface called CTRL9
- (4) Count Register for time stamping the sensor samples
- (5) Sensor data registers
- (6) FIFO Registers: to set up the FIFO and detect data availability and over-run
- (7) Activity Detection status registers
- (8) General Purpose Registers

Table 20. UI Register Overview

| Name              | Туре      | Register Address |        |            | Default      | Comment                                                |
|-------------------|-----------|------------------|--------|------------|--------------|--------------------------------------------------------|
| Nume              | Type      | Dec              | Hex    | Binary     | Binary       |                                                        |
| General Purpose   | Register  | s                |        |            |              |                                                        |
| WHO_AM_I          | r         | 0                | 00     | 00000000   | 00000101     | Device Identifier                                      |
| REVISION_ID       | r         | 1                | 01     | 0000001    | 01111100     | Device Revision ID                                     |
| Setup and Contro  | l Registe | ers              |        |            |              |                                                        |
| CTRL1             | rw        | 2                | 02     | 00000010   | 00100000     | SPI Interface and Sensor Enable                        |
| CTRL2             | rw        | 3                | 03     | 00000011   | 00000000     | Accelerometer: Output Data Rate, Full Scale, Self-Test |
| CTRL3             | rw        | 4                | 04     | 00000100   | 00000000     | Gyroscope: Output Data Rate, Full Scale, Self-Test     |
| Reserved          | rw        | 5                | 05     | 00000101   | 00000000     | Reserved                                               |
| CTRL5             | rw        | 6                | 06     | 00000110   | 00000000     | Low pass filter setting                                |
| Reserved          | rw        | 7                | 07     | 00000111   | 00000000     | Reserved                                               |
| CTRL7             | rw        | 8                | 08     | 00001000   | 00000000     | Enable Sensors                                         |
| CTRL8             | rw        | 9                | 09     | 00001001   | 00000000     | Motion Detection Control                               |
| CTRL9             | rw        | 10               | 0A     | 00001010   | 00000000     | Host Commands                                          |
| Host Controlled C | alibratio | n Reg            | isters | (See CTRL9 | , Usage is C | Optional)                                              |
| CAL1_L            | rw        | 11               | 0B     | 00001011   | 00000000     | Calibration Register                                   |
| CAL1_H            | rw        | 12               | 0C     | 00001100   | 00000000     | CAL1_L – lower 8 bits. CAL1_H – upper 8 bits.          |
| CAL2_L            | rw        | 13               | 0D     | 00001101   | 00000000     | Calibration Register                                   |
| CAL2_H            | rw        | 14               | 0E     | 00001110   | 00000000     | CAL2_L – lower 8 bits. CAL2_H – upper 8 bits.          |
| CAL3_L            | rw        | 15               | 0F     | 00001111   | 00000000     | Calibration Register                                   |
| CAL3_H            | rw        | 16               | 10     | 00010000   | 00000000     | CAL3_L – lower 8 bits. CAL3_H – upper 8 bits.          |
| CAL4_L            | rw        | 17               | 11     | 00010001   | 00000000     | Calibration Register                                   |
| CAL4_H            | rw        | 18               | 12     | 00010010   | 00000000     | CAL4_L – lower 8 bits. CAL4_H – upper 8 bits.          |
| FIFO Registers    | •         |                  |        |            | •            |                                                        |



| FIFO_WTM_TH         rw         19         13         00010011         00000000         FIFO watermark level, in OI           FIFO_CTRL         rw         20         14         00010100         00000000         FIFO Setup           FIFO_SMPL_CNT         r         21         15         00010101         00000000         FIFO sample count LSBs           FIFO_STATUS         r         22         16         00010110         00000000         FIFO Status           FIFO_DATA         r         23         17         00010111         00000000         FIFO Data           Status Registers           STATUSINT         r         45         2D         00101101         00000000         Sensor Data Availability witt CmdDone (CTRL9 protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | DRs                            |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------|
| FIFO_SMPL_CNT         r         21         15         00010101         00000000         FIFO sample count LSBs           FIFO_STATUS         r         22         16         00010110         00000000         FIFO Status           FIFO_DATA         r         23         17         00010111         00000000         FIFO Data           Status Registers   STATUSINT  The sample count LSBs  FIFO_Status  FIFO_DATA  FIFO_DATA  FIFO_DATA  Status Registers  STATUSINT  FIFO_STATUSINT  FIFO_STA |                                |
| FIFO_STATUS r 22 16 00010110 00000000 FIFO Status  FIFO_DATA r 23 17 00010111 00000000 FIFO Data  Status Registers  STATUSINT r 45 2D 00101101 00000000 Sensor Data Availability with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                |
| FIFO_DATA r 23 17 00010111 00000000 FIFO Data  Status Registers  STATUSINT r 45 2D 00101101 00000000 Sensor Data Availability with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| Status Registers  STATUSINT r 45 2D 00101101 00000000 Sensor Data Availability with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |                                |
| STATUSINT r 45 2D 00101101 00000000 Sensor Data Availability with                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                                |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                                |
| Sind Sono (Sintes protocol                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |                                |
| STATUS0 r 46 2E 00101110 00000000 Output Data Over Run and                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Data Availability.             |
| STATUS1 r 47 2F 00101111 00000000 Miscellaneous Status: Any I Motion, Tap.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | Motion, No Motion, Significant |
| Timestamp Register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| TIMESTAMP_ r 48 30 00110000 00000000 Sample Time Stamp TIMESTAMP_LOW – lower                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | r 8 bits.                      |
| TIMESTAMP_MID r 49 31 00110001 00000000 TIMESTAMP_MID - middle                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                |
| TIMESTAMP_HIGH r 50 32 00110010 00000000 TIMESTAMP_HIGH - uppe                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | er 8 bits                      |
| Data Output Registers (16 bits 2's Complement Except COD Sensor Data)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |                                |
| TEMP_L r 51 33 00110011 00000000 Temperature Output Data                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| TEMP_H r 52 34 00110100 00000000 TEMP_L – lower 8 bits. TEM                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | MP_H – upper 8 bits            |
| AX_L r 53 35 00110101 00000000 X-axis Acceleration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| AX_H r 54 36 00110110 00000000 AX_L – lower 8 bits. AX_H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <ul><li>upper 8 bits</li></ul> |
| AY_L r 55 37 00110111 00000000 Y-axis Acceleration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| AY_H r 56 38 00111000 00000000 AY_L – lower 8 bits. AY_H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | <ul><li>upper 8 bits</li></ul> |
| AZ_L r 57 39 00111001 00000000 Z-axis Acceleration                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| AZ_H r 58 3A 00111010 00000000 AZ_L – lower 8 bits. AZ_H -                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            | – upper 8 bits                 |
| GX_L r 59 3B 00111011 00000000 X-axis Angular Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| GX_H r 60 3C 00111100 00000000 GX_L – lower 8 bits. GX_H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | – upper 8 bits                 |
| GY_L r 61 3D 00111101 00000000 Y-axis Angular Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| GY_H r 62 3E 00111110 00000000 GY_L – lower 8 bits. GY_H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | – upper 8 bits                 |
| GZ_L r 63 3F 00111111 00000000 Z-axis Angular Rate                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |                                |
| GZ_H r 64 40 01000000 00000000 GZ_L – lower 8 bits. GZ_H                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              | – upper 8 bits                 |
| COD Indication and General Purpose Registers                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |                                |
| COD_STATUS r 70 46 01000110 00000000 Calibration-On-Demand sta                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | itus register                  |
| dQW_L r 73 49 01001001 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQW_H r 74 4A 01001010 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQX_L r 75 4B 01001011 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQX_H r 76 4C 01001100 00000000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQY_L r 77 4D 01001101 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQY_H r 78 4E 01001110 00000000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQZ_L r 79 4F 01001111 00000000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dQZ_H r 80 50 01010000 00000000 Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dVX_L r 81 51 01010001 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dVX_H r 82 52 01010010 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dVY_L r 83 53 01010011 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |
| dVY_H r 84 54 01010100 00000000 General purpose register                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                |







| dVZ_L                               | r                                                                          | 85 | 55                                      | 01010101 | 00000000 | General purpose register |  |  |
|-------------------------------------|----------------------------------------------------------------------------|----|-----------------------------------------|----------|----------|--------------------------|--|--|
| dVZ_H                               | r                                                                          | 86 | 56                                      | 01010110 | 00000000 | General purpose register |  |  |
| Activity Detection Output Registers |                                                                            |    |                                         |          |          |                          |  |  |
| TAP_STATUS                          | P_STATUS r 89 59 01011001 00000000 Axis, direction, number of detected Tap |    | Axis, direction, number of detected Tap |          |          |                          |  |  |
| Reset Register                      |                                                                            |    |                                         |          |          |                          |  |  |
| RESET                               | w                                                                          | 96 | 60                                      | 01100000 | 00000000 | Soft Reset Register      |  |  |



#### 5. UI SENSOR CONFIGURATION SETTINGS AND OUTPUT DATA

#### 5.1 Typical Sensor Mode Configuration and Output Data

In Typical sensor mode, QMI8658A outputs raw sensor values. The sensors are configured and read using the registers described below. The accelerometer and gyroscope can be independently configured. *Table 21* summarizes these pertinent registers.

Table 21. Typical Sensor Mode Configuration and Output Data

| Typical Sensor Configuration and Output Data |                                  |      |                                                                                                                          |  |  |  |
|----------------------------------------------|----------------------------------|------|--------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Description Registers U                      |                                  | Unit | Comments                                                                                                                 |  |  |  |
| Sensor Enable, SPI 3 or 4<br>Wire            | CTRL1                            |      | Control power states, configure SPI communications                                                                       |  |  |  |
| Enable Sensor                                | CTRL7                            |      | Individually Enable/Disable the AttitudeEngine, Accelerometer, and Gyroscope Using sEN, aEN, and gEN bits, respectively. |  |  |  |
| Configure Accelerometer,<br>Enable Self-Test | CTRL2                            |      | Configure Full Scale and Output Data Rate; Enable Self-Test                                                              |  |  |  |
| Configure Gyroscope, Enable<br>Self-Test     | CTRL3                            |      | Configure Full Scale and Output Data Rate; Enable Self-Test                                                              |  |  |  |
| Sensor Filters                               | CTRL5                            |      | Configure and Enable/Disable Low Pass Filters                                                                            |  |  |  |
| Status                                       | STATUSINT<br>STATUS0,<br>STATUS1 |      | Data Availability, FIFO Ready to be Read, CTRL9 Protocol Bit                                                             |  |  |  |
| Time Stamp                                   | TIMESTAMP[H<br>,M,L]             |      | Sample Time Stamp (Circular Register 0 – 0xFFFFFF)                                                                       |  |  |  |
| Acceleration                                 | A[X,Y,Z]_[H,L]                   | g    | In Sensor Frame of Reference, Right-handed Coordinate System                                                             |  |  |  |
| Angular Rate                                 | G[X,Y,Z]_[H,L]                   | dps  | In Sensor Frame of Reference, Right-handed Coordinate System                                                             |  |  |  |
| Temperature                                  | TEMP_[H,L]                       | °C   | Temperature of the Sensor                                                                                                |  |  |  |
| FIFO Based Output                            | FIFO_DATA                        |      | 1 Byte FIFO Data Outputs                                                                                                 |  |  |  |

#### 5.2 Chip Information Register

Table 22. Chip Information Register Description

|       | Register Name |                            |                                                                             |  |  |  |
|-------|---------------|----------------------------|-----------------------------------------------------------------------------|--|--|--|
| WHO.  | _AM_I         | Register Address: 0 (0x00) |                                                                             |  |  |  |
| Bits  | Name          | Default Description        |                                                                             |  |  |  |
| 7:0   | WHO_AM_I      | 0x05                       | Device identifier 0x05 - to identify the device is a QST sensor. Read-only. |  |  |  |
| REVIS | SION_ID       | Register Addre             | ss: 1 (0x01)                                                                |  |  |  |
| Bits  | Name          | Default                    | Description                                                                 |  |  |  |
| 7:0   | REVISION_ID   | 0x7C                       | Device Revision ID. Read-only.                                              |  |  |  |



# 5.3 Configuration Registers

This section describes the various operating modes and register configurations of the QMI8658A.

Table 23. Configuration Registers Description

| Re   | gister Name     |                                                                |                                           |                                                                                                                                                                              |                                         |           |            |  |  |
|------|-----------------|----------------------------------------------------------------|-------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------|-----------|------------|--|--|
| CTRL | _1              | Serial Interface and Sensor Enable. Register Address: 2 (0x02) |                                           |                                                                                                                                                                              |                                         |           |            |  |  |
| Bits | Name            | Default                                                        |                                           | Description                                                                                                                                                                  |                                         |           |            |  |  |
| 7    | SIM             | 1'b0                                                           |                                           | 0: Enables 4-wire SPI interface<br>1: Enables 3-wire SPI interface                                                                                                           |                                         |           |            |  |  |
| 6    | ADDR_AI         | 1'b0                                                           |                                           | 0: Serial interface (SPI, I <sup>2</sup> C, I <sup>3</sup> C) address non-increment.<br>1: Serial interface (SPI, I <sup>2</sup> C, I <sup>3</sup> C) address auto increment |                                         |           |            |  |  |
| 5    | BE              | 1'b1                                                           |                                           | 0: Serial interface (SPI, I <sup>2</sup> C, I <sup>3</sup> C) read data Little-Endian 1: Serial interface (SPI, I <sup>2</sup> C, I <sup>3</sup> C) read data Big-Endian     |                                         |           |            |  |  |
| 4    | INT2_EN         | 1'b0                                                           | 1                                         | n is high-Z mode<br>n output is enabled                                                                                                                                      | d                                       |           |            |  |  |
| 3    | INT1_EN         | 1'b0                                                           |                                           | n is high-Z mode<br>n output is enabled                                                                                                                                      | d                                       |           |            |  |  |
| 2    | FIFO_INT_SEL    | 1'b0                                                           |                                           | errupt is mapped<br>errupt is mapped                                                                                                                                         | •                                       |           |            |  |  |
| 1    | Reserved        | 1'b0                                                           |                                           |                                                                                                                                                                              |                                         |           |            |  |  |
| 0    | SensorDisable   | 1'b0                                                           |                                           | O: Enable internal high-speed oscillator  1: Disable internal high-speed oscillator. Refer to 7.1.                                                                           |                                         |           |            |  |  |
| CTRL | 2               | Accelerom                                                      | Accelerometer Settings: Address: 3 (0x03) |                                                                                                                                                                              |                                         |           |            |  |  |
| Bits | Name            | Default                                                        |                                           | Description                                                                                                                                                                  |                                         |           |            |  |  |
| 7    | aST             | 1'b0                                                           |                                           | Accelerometer Se<br>Accelerometer Se                                                                                                                                         | •                                       |           |            |  |  |
| 6:4  | aFS<2:0>        | 3'b0                                                           | 000 - Acce<br>001 - Acce<br>010 - Acce    | erometer Full-scale<br>elerometer Full-scalerometer Full-scale<br>elerometer Full-scale<br>elerometer Full-scale                                                             | ale = ±2 g<br>ale = ±4 g<br>ale = ±8 g  |           |            |  |  |
|      |                 |                                                                | Set Accele                                | rometer Output D                                                                                                                                                             | ata Rate (ODR):                         |           |            |  |  |
|      |                 |                                                                | Setting                                   | ODR Rate (Hz)<br>(Accel only)                                                                                                                                                | ODR Rate (Hz)<br>(6DOF) <sup>(16)</sup> | Mode      | Duty Cycle |  |  |
|      |                 |                                                                | 0000                                      | N/A                                                                                                                                                                          | 7174.4                                  | Normal    | 100%       |  |  |
|      |                 |                                                                | 0001                                      | N/A                                                                                                                                                                          | 3587.2                                  | Normal    | 100%       |  |  |
|      |                 |                                                                | 0010                                      | N/A                                                                                                                                                                          | 1793.6                                  | Normal    | 100%       |  |  |
|      |                 |                                                                | 0011                                      | 1000                                                                                                                                                                         | 896.8                                   | Normal    | 100%       |  |  |
|      | aODR<3:0>(15)(1 | 411                                                            | 0100                                      | 500                                                                                                                                                                          | 448.4                                   | Normal    | 100%       |  |  |
| 3:0  | 6)              | 4'b0                                                           | 0101                                      | 250                                                                                                                                                                          | 224.2                                   | Normal    | 100%       |  |  |
|      |                 |                                                                | 0110                                      | 125                                                                                                                                                                          | 112.1                                   | Normal    | 100%       |  |  |
|      |                 |                                                                | 0111                                      | 62.5                                                                                                                                                                         | 56.05                                   | Normal    | 100%       |  |  |
|      |                 |                                                                | 1000                                      | 31.25                                                                                                                                                                        | 28.025                                  | Normal    | 100%       |  |  |
|      |                 |                                                                | 1001                                      | N/A                                                                                                                                                                          | N/A                                     |           |            |  |  |
|      |                 |                                                                | 1010                                      | N/A                                                                                                                                                                          | N/A                                     |           |            |  |  |
|      |                 |                                                                | 1011                                      | N/A                                                                                                                                                                          | N/A                                     |           |            |  |  |
|      |                 |                                                                | 1100                                      | 128                                                                                                                                                                          | N/A                                     | Low Power | 100%       |  |  |
|      |                 |                                                                | 1101                                      | 21                                                                                                                                                                           | N/A                                     | Low Power | 58%        |  |  |



| 1110 | 11 | N/A | Low Power | 31%  |          |
|------|----|-----|-----------|------|----------|
| 1111 | 3  | N/A | Low Power | 8.5% | <u> </u> |

Table 23. Configuration Register Description (Continued)

| Register Name      |                  |                                                                                                                                                                         |                                                                                                                        |       |                                                                        |
|--------------------|------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------|-------|------------------------------------------------------------------------|
| CTRL3              | Gyroscope Settin | ngs: Addre                                                                                                                                                              | ss 4 (0x04)                                                                                                            |       |                                                                        |
| Bits Name          | Default          |                                                                                                                                                                         |                                                                                                                        | Descr | iption                                                                 |
| 7 gST              | 1'b0             |                                                                                                                                                                         | 0: Disable Gyro self-Test 1: Enable Gyro Self-Test.                                                                    |       |                                                                        |
| 6:4 gFS<2:0>       | 3'b0             | Set Gyroscope Full-scale:<br>000 - ±16 dps<br>001 - ±32 dps<br>010 - ±64 dps<br>011 - ±128 dps<br>100 - ±256 dps<br>101 - ±512 dps<br>110 - ±1024dps<br>111 - ±2048 dps |                                                                                                                        |       |                                                                        |
| 3:0 gODR<3:0> (16) | 4'b0             |                                                                                                                                                                         | Scope Output D ODR Rate (Hz) 7174.4 3587.2 1793.6 896.8 448.4 224.2 112.1 56.05 28.025 N/A N/A N/A N/A N/A N/A N/A N/A |       | DR):  Duty Cycle  100%  100%  100%  100%  100%  100%  100%  100%  100% |

<sup>15.</sup> The accelerometer low power mode is only available when the gyroscope is disabled.16. In 6DOF mode (accelerometer and gyroscope are both enabled), the ODR is derived from the nature frequency of gyroscope, refer to section 3.5 for more information.



Table 23. Configuration Register Description (Continued)

| R    | egister Name   |                                                             |                                                                                                                                                                    |  |  |  |  |  |
|------|----------------|-------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|--|
| CTRL | 5              | Sensor Data Processing Settings. Register Address: 6 (0x06) |                                                                                                                                                                    |  |  |  |  |  |
| Bits | Bits Name Defa |                                                             | Description                                                                                                                                                        |  |  |  |  |  |
| 7    | Reserved       | 1'b0                                                        |                                                                                                                                                                    |  |  |  |  |  |
| 6:5  | gLPF_MODE      | 2'b0                                                        | gLPF_MODE         BW [Hz]           00         2.66% of ODR           01         3.63% of ODR           10         5.39% of ODR           11         13.37% of ODR |  |  |  |  |  |
| 4    | gLPF_EN        | 1'b0                                                        | 0: Disable Gyroscope Low-Pass Filter.     1: Enable Gyroscope Low-Pass Filter with the mode given by gLPF_MODE.                                                    |  |  |  |  |  |
| 3    | Reserved       | 1'b0                                                        |                                                                                                                                                                    |  |  |  |  |  |
| 2:1  | aLPF_MODE      | 2'b0                                                        | aLPF_MODE         BW [Hz]           00         2.66% of ODR           01         3.63% of ODR           10         5.39% of ODR           11         13.37% of ODR |  |  |  |  |  |
| 0    | aLPF_EN        | 1'b0                                                        | O: Disable Accelerometer Low-Pass Filter.  1: Enable Accelerometer Low-Pass Filter with the mode given by aLPF_MODE.                                               |  |  |  |  |  |



Table 23. Configuration Register Description (Continued)

| CTRL7<br>Bits |                      |           |                                                                                                                                                                        |  |  |  |
|---------------|----------------------|-----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
|               | 7                    | Enable Se | ensors and Configure Data Reads. Register Address: 8 (0x08)                                                                                                            |  |  |  |
| 7             | Name                 | Default   | Description                                                                                                                                                            |  |  |  |
| ,             | SyncSample           | 1'b0      | 0: Disable SyncSample mode                                                                                                                                             |  |  |  |
|               | Syncoample           | 1 00      | 1: Enable SyncSample mode                                                                                                                                              |  |  |  |
| 6             | Reserved             | 1'b0      |                                                                                                                                                                        |  |  |  |
| 5             | DRDY_DIS             | 1'b0      | 0: DRDY(Data Ready) is enabled, is driven to the INT2 pin 1: DRDY(Data Ready) is disabled, is blocked from the INT2 pin                                                |  |  |  |
| 4             | gSN                  | 1'b0      | : Gyroscope in Full Mode (Drive and Sense are enabled). : Gyroscope in Snooze Mode (only Drive enabled). his bit is effective only when gEN is set to 1. Refer to 7.1. |  |  |  |
| 3:2           | Reserved             | 2'b0      |                                                                                                                                                                        |  |  |  |
| 1             | gEN                  | 1'b0      | 0: Disable Gyroscope. 1: Enable Gyroscope.                                                                                                                             |  |  |  |
| 0             | aEN                  | 1'b0      | Disable Accelerometer.     Enable Accelerometer.                                                                                                                       |  |  |  |
| CTRL          | 3                    | Motion De | etection Control. Register Address: 9 (0x09)                                                                                                                           |  |  |  |
| Bits          | Name                 | Default   | Description                                                                                                                                                            |  |  |  |
| 7             | CTRL9_HandShak       | 1b'0      | 0: use INT1 as CTRL9 handshake                                                                                                                                         |  |  |  |
|               | e_Type               |           | 1: use STATUSINT.bit7 as CTRL9 handshake                                                                                                                               |  |  |  |
| 6             | ACTIVITY_INT_SE<br>L | 1b'0      | 0: INT2 is used for Activity Detection event interrupt 1: INT1 is used for Activity Detection event interrupt                                                          |  |  |  |
|               |                      | 45.0      | Note: this bit influences the Any/No/Sig-motion, Tap Detection interrupt                                                                                               |  |  |  |
| 5             | reserved .           | 1b'0      |                                                                                                                                                                        |  |  |  |
| 4             | reserved             | 1b'0      |                                                                                                                                                                        |  |  |  |
| 3             | Sig-Motion_EN        | 1b'0      | disable Significant Motion engine     enable Significant Motion engine                                                                                                 |  |  |  |
| 2             | No-Motion_EN         | 1b'0      | 0: disable No Motion engine 1: enable No Motion engine                                                                                                                 |  |  |  |
| 1             | Any-Motion_EN        | 1b'0      | 0: disable Any Motion engine 1: enable Any Motion engine                                                                                                               |  |  |  |
| 0             | Tap_EN               | 1b'0      | 0: disable Tap engine 1: enable Tap engine                                                                                                                             |  |  |  |
| R             | egister Name         |           | 1                                                                                                                                                                      |  |  |  |
|               |                      |           | nands. Register Address: 10 (0x0A), Referred to:                                                                                                                       |  |  |  |



# CTRL 9 Functionality (Executing Pre-defined Commands)

# 5.4 FIFO Registers

Table 24. FIFO Control/Status/Data Registers

|       | Register Name         |                                          |                                                                                                                                                                                                                                                                                                                                                               |                                               |                  |  |  |  |
|-------|-----------------------|------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------|------------------|--|--|--|
| FIFO_ | FIFO_WTM_TH           |                                          | FIFO Watermark Register Address: 19 (0x13)                                                                                                                                                                                                                                                                                                                    |                                               |                  |  |  |  |
| Bits  | Name                  | Default                                  | Description                                                                                                                                                                                                                                                                                                                                                   |                                               |                  |  |  |  |
| 7:0   | FIFO_WTM              | 8'h0                                     | Number of ODRs (Samples) needed to trigger FIFO watermark                                                                                                                                                                                                                                                                                                     |                                               |                  |  |  |  |
| FIFO_ | CTRL                  | FIFO Control Register Address: 20 (0x14) |                                                                                                                                                                                                                                                                                                                                                               |                                               |                  |  |  |  |
| Bits  | Name                  | Default                                  | Description                                                                                                                                                                                                                                                                                                                                                   |                                               |                  |  |  |  |
| 7     | FIFO_RD_MODE          | 1'b0                                     | 0: FIFO is in Write mode, sensor data (if enabled) can be filled into FIFO 1: FIFO is in Read mode, FIFO data can be read via FIFO_DATA register This bit is automatically set by using a CTRL9 command. It must be cleared again (by write 1'b0 to this bit) after the data read is complete so that filling data to the FIFO can resume. Refer to 5.10.6.3. |                                               |                  |  |  |  |
| 6:4   | Reserved              | 3'b0                                     |                                                                                                                                                                                                                                                                                                                                                               |                                               |                  |  |  |  |
|       |                       |                                          | FIFO_SIZE[1:0]                                                                                                                                                                                                                                                                                                                                                | FIFO Sample Size                              |                  |  |  |  |
|       |                       |                                          | 00                                                                                                                                                                                                                                                                                                                                                            | 16 samples                                    |                  |  |  |  |
| 3:2   | FIFO_SIZE             | 2'b0                                     | 01                                                                                                                                                                                                                                                                                                                                                            | 32 samples                                    |                  |  |  |  |
|       |                       |                                          | 10                                                                                                                                                                                                                                                                                                                                                            | 64 samples                                    |                  |  |  |  |
|       |                       |                                          | 11                                                                                                                                                                                                                                                                                                                                                            | 128 samples                                   |                  |  |  |  |
|       |                       | 2'b0                                     | FIFO_MODE[1:0]                                                                                                                                                                                                                                                                                                                                                | FIFO Mode                                     |                  |  |  |  |
|       |                       |                                          | 00                                                                                                                                                                                                                                                                                                                                                            | Bypass (FIFO disable)                         |                  |  |  |  |
| 1:0   | FIFO_MODE             |                                          | 01                                                                                                                                                                                                                                                                                                                                                            | FIFO                                          |                  |  |  |  |
|       |                       |                                          | 10                                                                                                                                                                                                                                                                                                                                                            | Stream                                        |                  |  |  |  |
|       |                       |                                          | 11                                                                                                                                                                                                                                                                                                                                                            | Reserved                                      |                  |  |  |  |
| FIFO_ | SMPL_CNT              | FIFO Sam                                 | ple Count Register                                                                                                                                                                                                                                                                                                                                            | Address: 21 (0x15)                            |                  |  |  |  |
| Bits  | Name                  | Default                                  | Description                                                                                                                                                                                                                                                                                                                                                   |                                               |                  |  |  |  |
| 7:0   | FIFO_SMPL_CNT_LS<br>B | 8'b0                                     | 8 LS bits of FIFO Sar                                                                                                                                                                                                                                                                                                                                         | nple Count, in word (2bytes).                 |                  |  |  |  |
| FIFO_ | STATUS                | FIFO Stat                                | us. Register Addre                                                                                                                                                                                                                                                                                                                                            | ss 22 (0x16)                                  |                  |  |  |  |
| Bits  | Name                  | Default                                  |                                                                                                                                                                                                                                                                                                                                                               | Description                                   |                  |  |  |  |
| 7     | FIFO_FULL             | 1'b0                                     | 0: FIFO is not Full 1: FIFO is Full                                                                                                                                                                                                                                                                                                                           |                                               |                  |  |  |  |
| 6     | FIFO_WTM              | 1'b0                                     | 0: FIFO Water Mark Level not hit. 1: FIFO Water Mark Level Hit                                                                                                                                                                                                                                                                                                |                                               |                  |  |  |  |
| 5     | FIFO_OVFLOW           | 1'b0                                     | 0: FIFO Overflow has<br>1: FIFO Overflow con                                                                                                                                                                                                                                                                                                                  | not happened<br>dition has happened (data dro | opping happened) |  |  |  |



| 4     | FIFO_NOT_EMPTY        | 1'b0     | 0: FIFO is Empty 1: FIFO is not Empty            |
|-------|-----------------------|----------|--------------------------------------------------|
| 3:2   | Reserved              | 2'b0     |                                                  |
| 1:0   | FIFO_SMPL_CNT_M<br>SB | 2'b0     | 2 MS bits of FIFO Sample Count in word (2bytes). |
| FIFO_ | DATA                  | FIFO DAT | A Output Register Address: 23 (0x17)             |
| Bits  | Name                  | Default  | Description                                      |
| 7:0   | FIFO_DATA             | 8'b0     | 8 bit FIFO data output.                          |

# 5.5 Status and Time Stamp Registers

Table 25. Status and Time Stamp Registers

| F         | Register Name      |                                                            |                                                                                                                                                                       |  |
|-----------|--------------------|------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| STATUSINT |                    | Sensor Data Available and Lock Register Address: 45 (0x2D) |                                                                                                                                                                       |  |
| Bits      | Name               | Default                                                    | Description                                                                                                                                                           |  |
| 7         | Ctrl9 CmdDone      | 1'b0                                                       | Indicates CTRL9 Command was done, as part of CTRL9 protocol 0: Not Completed 1: Done                                                                                  |  |
| 6:2       | Reserved           | 5'b0                                                       |                                                                                                                                                                       |  |
| 1         | Locked             | 1'b0                                                       | If syncSmpl (CTRL7.bit7) = 1: 0: Sensor Data is not locked. 1: Sensor Data is locked. If syncSmpl = 0, this bit shows the same value of INT1 level                    |  |
| 0         | Avail              | 1'b0                                                       | If syncSmpl (CTRL7.bit7) = 1:  0: Sensor Data is not available  1: Sensor Data is available for reading  If syncSmpl = 0, this bit shows the same value of INT2 level |  |
| STATUS0   |                    | Output Data Status Register Address: 46 (0x2E)             |                                                                                                                                                                       |  |
| Bits      | Name               | Default                                                    | Description                                                                                                                                                           |  |
| 7:2       | Reserved           | 6'b0                                                       |                                                                                                                                                                       |  |
| 1         | gDA                | 1'b0                                                       | Gyroscope new data available 0: No updates since last read. 1: New data available.                                                                                    |  |
| 0         | aDA                | 1'b0                                                       | Accelerometer new data available 0: No updates since last read. 1: New data available.                                                                                |  |
| STATUS1   |                    | Miscellaneous S                                            | Status. Register Address 47 (0x2F)                                                                                                                                    |  |
| Bits      | Name               | Default                                                    | Description                                                                                                                                                           |  |
| 7         | Significant Motion | 1'b0                                                       | No Significant-Motion was detected     Significant-Motion was detected                                                                                                |  |
| 6         | No Motion          | 1'b0                                                       | 0: No No-Motion was detected 1: No-Motion was detected                                                                                                                |  |
| 5         | Any Motion         | 1'b0                                                       | 0: No Any-Motion was detected 1: Any-Motion was detected                                                                                                              |  |
| 4         | Reserved           | 1'b0                                                       |                                                                                                                                                                       |  |
| 3         | Reserved           | 1'b0                                                       |                                                                                                                                                                       |  |



| 2         | Reserved               | 1'b0                                      |                                                                                                                                               |  |
|-----------|------------------------|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------|--|
| 1         | TAP                    | 1'b0                                      | 0: No Tap was detected                                                                                                                        |  |
| '         |                        |                                           | 1: Tap was detected                                                                                                                           |  |
| 0         | Reserved               | 1'b0                                      |                                                                                                                                               |  |
| TIMESTAMP |                        | 3 Bytes Sample Time Stamp – Output Count. |                                                                                                                                               |  |
|           |                        | Register Address: 48 - 50(0x30 - 0x32)    |                                                                                                                                               |  |
| Bits      | 1                      |                                           |                                                                                                                                               |  |
| DILS      | Name                   | Default                                   | Description                                                                                                                                   |  |
| 7:0       | Name TIMESTAMP_L<7:0 > | Ox00                                      | ·                                                                                                                                             |  |
|           | TIMESTAMP_L<7:0        |                                           | Sample time stamp. Count incremented by one for each sample (x, y, z data set) from sensor with highest ODR (circular register 0x0-0xFFFFFF). |  |

# 5.6 Sensor Data Output Registers

Table 26. Sensor Data Output Registers Description

| Register Name  |            |                                                    |                                                                                     |  |
|----------------|------------|----------------------------------------------------|-------------------------------------------------------------------------------------|--|
| TEMP_[H,L]     |            | Temp Sensor Output. Register Address: 0x33 – 0x34  |                                                                                     |  |
| Bits           | Name       | Default                                            | Description                                                                         |  |
| 7:0            | TEMP_L     | 0x00                                               | Temperature output (°C) in two's complement.                                        |  |
| 7:0            | TEMP_H     | 0x00                                               | Refer to 3.9 for details.                                                           |  |
| Register Name  |            |                                                    |                                                                                     |  |
| A[X,Y,Z]_[H,L] |            | Acceleration Output. Register Address: 0x35 – 0x3A |                                                                                     |  |
| Bits           | Name       | Default                                            | Description                                                                         |  |
| 7:0            | AX_L<7:0>  | 0x00                                               | X-axis acceleration in two's complement.  AX_L – lower 8 bits. AX_H – upper 8 bits. |  |
| 7:0            | AX_H<15:8> | 0x00                                               |                                                                                     |  |
| 7:0            | AY_L<7:0>  | 0x00                                               | Y-axis acceleration in two's complement.  AY_L – lower 8 bits. AY_H – upper 8 bits. |  |
| 7:0            | AY_H<15:8> | 0x00                                               |                                                                                     |  |
| 7:0            | AZ_L<7:0>  | 0x00                                               | Z-axis acceleration in two's complement.                                            |  |
| 7:0            | AZ_H<15:8> | 0x00                                               | AZ_L – lower 8 bits. AZ_H – upper 8 bits.                                           |  |
| Register Name  |            |                                                    |                                                                                     |  |
| G[X,Y.Z]_[H,L] |            | Angular Rate Output. Register Address: 0x3B – 0x40 |                                                                                     |  |
| Bits           | Name       | Default                                            | Description                                                                         |  |
| 7:0            | GX_L<7:0>  | 0x00                                               | X-axis angular rate in two's complement. GX_L – lower 8 bits. GX_H – upper 8 bits.  |  |
| 7:0            | GX_H<15:8> | 0x00                                               |                                                                                     |  |
| 7:0            | GY_L<7:0>  | 0x00                                               | Y-axis angular rate in two's complement.                                            |  |
| 7:0            | GY_H<15:8> | 0x00                                               | GY_L – lower 8 bits. GY_H – upper 8 bits.                                           |  |
| 7:0            | GZ_L<7:0>  | 0x00                                               | Z-axis angular rate in two's complement.                                            |  |
| 7:0            | GZ_H<15:8> | 0x00                                               | GZ_L – lower 8 bits. GZ_H – upper 8 bits.                                           |  |



## 5.7 Calibration-On-Demand (COD) Status Register

| Register Name |                |                                                                                                                                     |                                                                                                                                                              |  |  |  |
|---------------|----------------|-------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| COD_          | COD_STATUS     |                                                                                                                                     | Register Address: 70 (0x46)                                                                                                                                  |  |  |  |
| Bits          | Name           | Default                                                                                                                             | Description                                                                                                                                                  |  |  |  |
| 7             | X_Limit_L_Fail | 1'b0                                                                                                                                | COD passed for checking low sensitivity limit of X axis of gyroscope     COD failed for checking low sensitivity limit of X axis of gyroscope                |  |  |  |
| 6             | X_Limit_H_Fail | 1'b0                                                                                                                                | COD passed for checking high sensitivity limit of X axis of gyroscope     COD failed for checking high sensitivity limit of X axis of gyroscope              |  |  |  |
| 5             | Y_Limit_L_Fail | 1'b0                                                                                                                                | COD passed for checking low sensitivity limit of Y axis of gyroscope     COD failed for checking low sensitivity limit of Y axis of gyroscope                |  |  |  |
| 4             | Y_Limit_H_Fail | 1'b0                                                                                                                                | COD passed for checking high sensitivity limit of Y axis of gyroscope     COD failed for checking high sensitivity limit of Y axis of gyroscope              |  |  |  |
| 3             | Accel_Check    | 1'b0                                                                                                                                | O: Accelerometer checked pass (no significant vibration happened during COD)     1: Accelerometer checked failed (significant vibration happened during COD) |  |  |  |
| 2             | Startup_Failed | 1'b0                                                                                                                                | O: Gyroscope startup succeeded     Syroscope startup failure happened when COD was called                                                                    |  |  |  |
| 1             | Gyro_Enabled   | o_Enabled  1'b0  0: COD was called when gyroscope was not enabled 1: COD was called while gyroscope was enabled, COD return failure |                                                                                                                                                              |  |  |  |
| 0             | COD_Failed     | 1'b0                                                                                                                                | 0: COD succeeded, new gain parameters will be applied to GX & GY data 1: COD failed; no COD correction applied                                               |  |  |  |

Note the value of this register is only valid after the COD command. Refer to 12 Calibration-On-Demand (COD).



## 5.8 Activity Detection Output Registers

**Table 27. Activity Detection Output Registers** 

| Register Name    |              |                             |                                                                                                                              |  |  |
|------------------|--------------|-----------------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| TAP_STATUS       |              | Register Address: 89 (0x59) |                                                                                                                              |  |  |
| Bits             | Name         | Default                     | Description                                                                                                                  |  |  |
| 7                | TAP_POLARITY | 1'b0                        | O: Tap was detected on the positive direction of the Tap axis  1: Tap was detected on the negative direction of the Tap axis |  |  |
| 6                | Reserved     | 1'b0                        |                                                                                                                              |  |  |
| 5:4              | TAP_AXIS     | 2'b0                        | 0: No Tap was detected 1: Tap was detected on X axis 2: Tap was detected on Y axis 3: Tap was detected on Z axis             |  |  |
| 3:2              | Reserved     | 2'b0                        |                                                                                                                              |  |  |
| 1:0 TAP_NUM 2'b0 |              | 2'b0                        | 0: No Tap was detected 1: Single-Tap was detected 2: Double-Tap was detected 3: NA                                           |  |  |

## 5.9 Reset Register

**Table 28. Reset Register Description** 

| Register Name |       |                             |                                                                                                                      |
|---------------|-------|-----------------------------|----------------------------------------------------------------------------------------------------------------------|
| RESET         |       | Register Address: 96 (0x60) |                                                                                                                      |
| Bits          | Name  | Default Description         |                                                                                                                      |
|               |       |                             | Soft Reset Register - Write 0xB0 to this register from any modes, will trigger the sensor reset process immediately. |
| 7:0           | RESET | 0x00                        | The register 0x4D will equals to 0x80 if there is a successful reset (Power-on Reset or Soft Reset) process.         |
|               |       |                             | Refer to 7.4 Chip Reset Process.                                                                                     |



### 5.10 CTRL 9 Functionality (Executing Pre-defined Commands)

#### 5.10.1 CTRL9 Protocol Description

The protocol for executing predefined commands from an external host processor on the QMI8658A is facilitated by using the CTRL9 register. The register is available to the host via the UI SPI/I<sup>2</sup>C/I<sup>3</sup>C bus.

It operates by the host writing a pre-defined value (Command, refer to 5.10.2 CTRL9 Command List) to the CTRL9 register. The firmware of QMI8658A evaluates this command and if a match is found it executes the corresponding pre-defined function.

Once the function has been executed, the QMI8658A signals the completion by setting STATUSINT.bit7 to 1, and raising INT1 interrupt if CTRL1.bit3 = 1 & CTRL8.bit7 == 0. The host must acknowledge this by writing CTRL\_CMD\_ACK (0x00) to CTRL9 register. After receiving the CTRL\_CMD\_ACK command, the QMI8658A clears the STATUSINT.bit7 to 0 and pulls down the INT1 interrupt if CTRL1.bit3 = 1 & CTRL8.bit7 == 0.

This command presentation from the host to the QMI8658A and the subsequent execution and handshake between the host and the QMI8658A will be referred to as the "CTRL9 Protocol".

There are three types of interactions between the host and QMI8658A that follow the CTRL9 Protocol.

WCtrl9: The host needs to supply data to QMI8658A prior to the Ctrl9 protocol. (Write - Ctrl9 Protocol)

Ctrl9R: The host gets data from QMI8658A following the Ctrl9 protocol. (Ctrl9 protocol - Read)

Ctrl9: No data transaction is required prior to or following the Ctrl9 protocol. (Ctrl9).



Figure 13. CTRL9 Protocol Flow Chart



#### 5.10.2 CTRL9 Command List

The predefined CTRL9 commands are listed in Table 29 List of CTRL9 Command.

Table 29. List of CTRL9 Commands

| Command Name                     | CTRL9<br>Command<br>Value | Protocol<br>Type | Description                                                         |
|----------------------------------|---------------------------|------------------|---------------------------------------------------------------------|
| CTRL_CMD_ACK                     | 0x00                      | Ctrl9            | Acknowledgement. Host acknowledges to QMI8658, to end the protocol. |
| CTRL_CMD_RST_FIFO                | 0x04                      | Ctrl9            | Reset FIFO from Host                                                |
| CTRL_CMD_REQ_FIFO                | 0x05                      | Ctrl9R           | Get FIFO data from Device                                           |
| CTRL_CMD_ACCEL_HOST_DELTA_OFFSET | 0x09                      | WCtrl9           | Change accelerometer offset                                         |
| CTRL_CMD_GYRO_HOST_DELTA_OFFSET  | 0x0A                      | WCtrl9           | Change gyroscope offset                                             |
| CTRL_CMD_CONFIGURE_TAP           | 0x0C                      | WCtrl9           | Configure Tap detection                                             |
| CTRL_CMD_CONFIGURE_MOTION        | 0x0E                      | WCtrl9           | Configure Any Motion / No Motion / Significant Motion detection     |
| CTRL_CMD_COPY_USID               | 0x10                      | Ctrl9R           | Copy USID and FW Version to UI registers                            |
| CTRL_CMD_SET_RPU                 | 0x11                      | WCtrl9           | Configures IO pull-ups                                              |
| CTRL_CMD_AHB_CLOCK_GATING        | 0x12                      | WCtrl9           | Internal AHB clock gating switch                                    |
| CTRL_CMD_ON_DEMAND_CALIBRATION   | 0xA2                      | WCtrl9           | On-Demand Calibration on gyroscope                                  |
| CTRL_CMD_APPLY_GYRO_GAINS        | 0xAA                      | WCtrl9           | Restore the saved Gyroscope gains                                   |

### 5.10.3 CAL Registers

The set of CAL registers can be used for the parameter transferring, if WCTL9 or CTRL9R commands are implemented. Refer to *Table 29* and *5.10.6* for details.

Table 30. CAL Register Addresses

| Posister Name | Register Address |      |  |
|---------------|------------------|------|--|
| Register Name | Dec              | Hex  |  |
| CAL1_L        | 11               | 0x0B |  |
| CAL1_H        | 12               | 0x0C |  |
| CAL2_L        | 13               | 0x0D |  |
| CAL2_H        | 14               | 0x0E |  |
| CAL3_L        | 15               | 0x0F |  |
| CAL3_H        | 16               | 0x10 |  |
| CAL4_L        | 17               | 0x11 |  |
| CAL4_H        | 18               | 0x12 |  |



#### 5.10.4 WCtrl9 (Write - CTRL9 Protocol)

- (1) The host needs to provide the required data for this command to QMI8658A. The host typically does this by placing the data in a set of registers called the CAL registers. A maximum of eight CAL registers are used. Refer to Table 30.
- (2) Write Ctrl9 register 0x0A with the appropriate Command value, refer to Table 29.
- (3) The Device will set STATUSINT.bit7 to 1, and raise INT1(if CTRL1.bit3 = 1 & CTRL8.bit7 == 0), once it has executed the appropriate function based on the command value.
- (4) The host must acknowledge this by writing CTRL\_CMD\_ACK (0x00) to CTRL9 register, STATUSINT.bit7 (CmdDone) will be reset to 0 on receiving the CTRL\_CMD\_ACK command. And INT1 is pulled low upon the register read if CTRL1.bit3 = 1 & CTRL8.bit7 == 0.
- (5) If any data is expected from the device, it will be available at this time. The location of the data is specified separately for each of the Commands.

Refer to 5.10.6 for details.

#### 5.10.5 Ctrl9R (CTRL9 Protocol - Read)

- (1) Write Ctrl9 register 0x0A with the appropriate Command value.
- (2) The Device will set STATUSINT.bit7 to 1, and raise INT1 (if CTRL1.bit3 = 1 & CTRL8.bit7 == 0), once it has executed the appropriate function based on the command value.
- (3) The host must acknowledge this by writing CTRL\_CMD\_ACK (0x00) to CTRL9 register, STATUSINT.bit7 (CmdDone) will be reset to 0 on receiving the CTRL\_CMD\_ACK command. INT1 is pulled low upon the register read if CTRL1.bit3 = 1 & CTRL8.bit7 == 0.
- (4) Data is available from the device on the CAL registers. The location of the data is specified separately for each of the Commands.

Refer to 5.10.6 for details.

#### 5.10.6 CTRL9 Commands in Details

#### 5.10.6.1 CTRL CMD ACK

Host acknowledges QMI8658A when received the CmdDone information, to end the CTRL9 protocol.

### 5.10.6.2 CTRL\_CMD\_RST\_FIFO

This CTRL9 command of writing 0x04 to the Ctrl9 register 0x0a allows the host to instruct the device to reset the FIFO. The FIFO data, sample count and flags will be cleared and reset to default status.

#### 5.10.6.3 CTRL\_CMD\_REQ\_FIFO

This CTRL9 Command is issued when the host wants to get data from the FIFO, by writing 0x05 through the CTRL9 process.

After successfully finish the CTRL9 process, the FIFO read mode will be enabled, the device will direct the FIFO data to the FIFO\_DATA register(0x17) until the FIFO is empty. After reading the FIFO data, host must set FIFO\_CTRL.FIFO\_rd\_mode to 0 by write the FIFO\_CTRL register, which will cause the FIFO\_STATUS.FIFO\_WTM/FIFO\_FULL to be cleared and/or the INT pin (if enabled) be de-asserted. Refer to 5.10.4 0 for CTRL9 operation, and refer to 8.8 for details.

### 5.10.6.4 CTRL\_CMD\_ACCEL\_HOST\_DELTA\_OFFSET

This CTRL9 Command is issued when the host wants to manually change the accelerometer offset. Each delta offset value should contain 16 bits and the format is signed 4.12 (12 fraction bits, unit is  $1/2^{12}$ ). The user must write the offset to the following registers:

Accel\_Delta\_X : {CAL1\_H, CAL1\_L} Accel\_Delta\_Y : {CAL2\_H, CAL2\_L} Accel\_Delta\_Z : {CAL3\_H, CAL3\_L}

Next, the Command is issued by writing 0x09 to CTRL9 register 0x0A. Note, this offset change is lost when the sensor is power cycled, or the system is reset.



#### 5.10.6.5 CTRL\_CMD\_GYRO\_HOST\_DELTA\_OFFSET

This CTRL9 Command is issued when the host wants to manually change the gyroscope offset. Each delta offset value should contain 16 bits and the format is signed 11.5 (5 fraction bits, unit is 1 / 2^5). The user must write the offset to the following registers:

```
Gyro_Delta_X : {CAL1_H, CAL1_L}
Gyro_Delta_Y : {CAL2_H, CAL2_L}
Gyro_Delta_Z : {CAL3_H, CAL3_L}
```

Next, the Command is issued by writing 0x0A to CTRL9 register 0x0A. Note, this offset change is lost when the sensor is power cycled, or the system is reset.

#### 5.10.6.6 CTRL\_CMD\_CONFIGURE\_TAP

This CTRL9 command is issued to configure the parameters of Tap detection. Refer to 10.3 Configure Tap for details.

#### 5.10.6.7 CTRL CMD CONFIGURE MOTION

This CTRL9 command is issued to configure the parameters of Motion Detection. Refer to *0 Config Motion* **Detection**.

#### 5.10.6.8 CTRL\_CMD\_COPY\_USID

The USID is the unique ID of every single QMI8658A part.

This CTRL9 Command copies the following data into UI registers. It is initiated by the host writing 0x10 to CTRL9. After issuing the command, the data will be available for the host to read from the registers shown below:

```
FW_Version byte 0 → dQW_L
FW_Version byte 1 → dQW_H
FW_Version byte 2 → dQX_L
USID_Byte_0 → dVX_L
USID_Byte_1 → dVX_H
USID_Byte_2 → dVY_L
USID_Byte_3 → dVY_H
USID_Byte_4 → dVZ_L
USID_Byte_5 → dVZ_H
```

Note that after the successful Power-On Reset or Soft-Reset, the FW\_Version and USID will be copied automatically to the according registers once for host to read them. Those registers can be changed after enabling the sensors, so afterwards, the CTRL\_CMD\_COPY\_USID command should be implemented to copy the FW\_Version and USID to the according registers before reading.

#### 5.10.6.9 CTRL\_CMD\_SET\_RPU

This CTRL9 Command is issued when the host configure the IO pull-up resistors. Each bit controls a combination of resistors as shown in *Table 31*:

| Table 3 | 1. Pu | II-Up∣ | Resist | tor T | able |
|---------|-------|--------|--------|-------|------|
|---------|-------|--------|--------|-------|------|

| Bit | Signal Name | Pins                                                                                     | Activity                                                          |
|-----|-------------|------------------------------------------------------------------------------------------|-------------------------------------------------------------------|
| 0   | aux_rpu_dis | SDx, SCx, RESV(Pin 10, CS- 0: enable pull-up resistors(AUX) 1: disable pull-up resistors |                                                                   |
| 1   | icm_rpu_dis | SDx, SCx                                                                                 | 0: enable pull-up resistor(default) 1: disable pull-up resistor   |
| 2   | cs_rpu_dis  | cs                                                                                       | 0: enable pull-up resistor(default) 1: disable pull-up resistor   |
| 3   | i2c_rpu_dis | SCL, SDA                                                                                 | 0: enable pull-up resistors(default) 1: disable pull-up resistors |



| 4:7 | Reserved | NA |  |
|-----|----------|----|--|
|     |          |    |  |

The host writes the appropriate CAL1\_L bit by issuing a WCtrl9 command with 0x11.

By default, all the pull-up resistors are enabled. Write 1 to the bit will disable the pullup resistors accordingly, while write 0 will enable the pull-up resistors.

All the signals listed in *Table 31* should be given a stable level, rather than floating (can cause high leakage current through the inside MOSFET of the signal ports). Therefore, it is forbidden to disable the internal pull-up resistors of the signals listed in the *Table 31* while leave those signals externally floating. Only when those signals was connected to stable levels accordingly externally, the corresponding internal pull-up resistors can be disabled.

#### 5.10.6.10 CTRL\_CMD\_AHB\_CLOCK\_GATING

When locking Mechanism is set (CTRL7.bit7 == 1(syncSmpl)), the CTRL\_CMD\_AHB\_CLOCK\_GATING should be disabled to guarantee the locking mechanism of data reading, to prevent the possible misalignment. Refer to 12 Calibration-On-Demand (COD) for details.

#### 5.10.6.11 CTRL\_CMD\_ON\_DEMAND\_CALIBRATION

This CTRL9 Command enables host to recalibrate the gyro sensitivity from time to time. Refer to 12 Calibration-On-Demand (COD).

#### 5.10.6.12 CTRL\_CMD\_APPLY\_GYRO\_GAINS

This CTRL9 Command enables host to restore the saved the gyro gains to QMI8658A, to avoid run the COD again. This is not recommended when there are significant environment changes, like significant PCB stress change. Refer to 12.4 Save and Restore the New Gain Parameters.



### 6. INTERRUPTS

The QMI8658A has two Interrupt lines, INT1 and INT2.

Both INT1 and INT2 can be configured as High-Z mode or Push-Pull mode by configuring the CTRL1.bit3(INT1) or CTRL1.bit4(INT2). If CTRL1.bit3 (CTRL1.bit4) is set to 0, INT1(INT2) will be set in High-Z mode accordingly. While if CTRL1.bit3 (CTRL1.bit4) is set to 1, INT1(INT2) will be set in Push-Pull mode accordingly. By default, INT1 and INT2 are in High-Z mode.

There are two modes of the interrupt map, as described below. The host can config multiple internal signal/interrupt sources to INT pins (INT1 and/or INT2). If driven to one INT pin, the multiple sources act in LOGIC-OR.

### 6.1 SyncSample mode

The SyncSample mode supports locking the values during the reading process. Refer to  $\boldsymbol{0}$ 



### Locking Mechanism.

For details to the sensor data registers.

Set CTRL7.bit7(SyncSample) == 1 will enable the SyncSample mode.

As illustrated in Figure 14. In SyncSample mode, the CTRL9 handshake signal will be routed to INT1. Check 5.10 for details.

The motion event interrupts (Any Motion, No Motion, Significant Motion, Tap) will be routed to INT1 if enabled.

FIFO function is not supported in this mode, and DRDY signal will be routed to INT2.



Figure 14. Interrupt Map of SyncSample Mode



### 6.2 Non-SyncSample mode

This mode supports FIFO function and free interrupts configuration, as illustrated in 0.

If CTRL7.bit7(SyncSample) == 0, then bit 1 of STATUSINT register will have the same value as INT1 and bit 0 of STATUSINT register will have the same value as INT2.

In Non-SyncSample mode, there are two approaches of CTRL9 handshake. Host can check the INT1 pin high level for the handshark if set CTRL8.bit7 = 0; or poll the STATUSINT.bit7 for handshake if set CTRL8.bit7 = 1.

In Non-SyncSample mode, the motion event interrupt(s) can be configured to INT1 by setting CTRL8.bit6 = 1, or to INT2 by setting CTRL8.bit6 = 0. Note that the motion event engines can be enabled by CTRL8.bit[4:0], refer to *Table 23* for details.

In Non-SycnSample mode, the sensor data can be output through data register or FIFO. Configure the FIFO\_CTRL.FIFO\_MODE = 'bypass' mode, will enable the DRDY function and disable FIFO functionality; configure the FIFO CTRL.FIFO MODE = other mode, will enable the FIFO functionality and disable the DRDY function.

If FIFO mode is enabled, the FIFO interrupt can be configured to INT1 pin if CTRL1.bit2 is set to 1, or INT2 pin if CTRL1.bit2 is set to 0. Refer to for more details of FIFO interrupt behavior.

If DRDY mode is enabled, the DRDY signal will be routed to INT2 if the CTRL7.bit5(DRDY\_DIS) is set to 0, or be blocked from INT2 pin if CTRL7.bit5(DRDY\_DIS) is set to 1.



Figure 15. Interrupt Map of SyncSample Mode



### 6.3 DRDY(Data Ready)

If DRDY mode is enabled (accelerometer and/or gyroscope are/is enabled, and FIFO mode is set to bypass) and DRDY\_DIS == 0, DRDY (Data Ready) signal will be driven to the INT2 in edge-trigger mode, means the DRDY signal can be seen on INT2. The Sensor Data Output Registers (refer to 5.6) are updated at the Output Data Rate (ODR), and DRDY signal is pulsed at the ODR frequency. The new data is updated to the data registers during the low level before the rising edge, and a rising edge on DRDY indicates that data is available for host to read. DRDY is cleared automatically after a short duration. The DRDY pulse width is dependent on the sensor ODR set by CTRL2 and/or CTRL3 registers and enabled sensor(s).

In Non-SyncSample mode, it is the responsibility of the host to detect the rising edge and to read the data out during the high level of the INT2 pulse. Otherwise, there is the possibility that the updating of the new data happens during the host reading process and causes data mismatch.

In SyncSample mode, it is possible to lock the data in the data registers and read them in an unlimited delay, by following a process. Refer to 6.1 SyncSample mode.

## 7. Operating Modes

The QMI8658A offers a large number of operating modes that may be used to operate the device in a power efficient manner. These modes are described in *Table 32* and are shown in *Figure 16*; they may be configured using the control (CTRL) registers.

### 7.1 Operating Modes Descriptions

**Table 32. Operating Modes** 

| Mode                 | Description                                                                                                                                                                                                                                                                                                                   | Suggested Configuration                                               |
|----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------|
| Power-On Default     | All sensors are off, clock is turned on. Note this mode is the default state upon initial power up or after a reset.                                                                                                                                                                                                          | CTRL1 sensorDisable = 0<br>CTRL7 aEN = 0, gEN = 0,<br>CTRL2 aODR =000 |
| Low Power            | Same as Power-On Default mode, except in this mode the 250 kHz clock is turned on instead of the high-speed clock. To enter this mode requires host interaction to set CTRL2 aODR=11xx.                                                                                                                                       | CTRL1 sensorDisable =0<br>CTRL7 aEN = 0, gEN = 0,<br>CTRL2 aODR =11xx |
| Power-Down           | All QMI8658A functional blocks are switched off to minimize power consumption. Digital interfaces remain on allowing communication with the device. All configuration register values are preserved, and output data register values are maintained. The host must initiate this mode by setting sensorDisable=1.             | CTRL1 sensorDisable =1<br>CTRL7 aEN = 0, gEN = 0                      |
| Normal Accel Only    | Device configured as an accelerometer only.                                                                                                                                                                                                                                                                                   | CTRL7 aEN =1, gEN =0,<br>CTRL2 aODR !=11xx                            |
| Low Power Accel Only | Device configured in low power accelerometer mode.                                                                                                                                                                                                                                                                            | CTRL7 aEN =1, gEN =0,<br>CTRL2 aODR =11xx                             |
| Snooze Gyro          | Device configured as gyroscope drive only, the gyroscope MEMS will keep running at resonance frequency. Since the Sensing part is not enabled, there is no data from the gyroscope in this mode. This mode enables relative lower current consumption than Gyro-Only mode and can quickly generate data from clearing of gSN. | CTRL7 gSN=1, aEN =0, gEN =1                                           |
| Gyro Only            | Device configured as a gyroscope only.                                                                                                                                                                                                                                                                                        | CTRL7 gSN=0, aEN =0, gEN =1                                           |
| Accel + Gyro (IMU)   | Device configured as an Inertial Measurement Unit, i.e. an accelerometer and gyroscope combination sensors.                                                                                                                                                                                                                   | CTRL7 gSN=0, aEN =1, gEN =1<br>CTRL2 aODR != 11xx                     |
| Accel + Snooze Gyro  | Accelerometer and gyroscope snooze are enabled. Only accelerometer data is available.                                                                                                                                                                                                                                         | CTRL7 gSN=1, aEN =1, gEN =1<br>CTRL2 aODR != 11xx                     |
| Software Reset       | Software Reset asserted                                                                                                                                                                                                                                                                                                       |                                                                       |
| No Power             | VDDIO and VDD low                                                                                                                                                                                                                                                                                                             |                                                                       |



### 7.2 General Mode Transitioning

Upon exiting the No Power state (i.e., on first applying power to the part) or exiting a Software Reset state, the part will enter the Power-On Default state. From there, the sensor can be configured in the various modes described in Table 32 and as shown in Figure 16. The figure illustrates the timing associated with various mode transitions, and values for these times are given in the section below and in Table 8 and Table 9.



Figure 16. Operating Mode Transition Diagram



#### 7.3 Transition Time

t0 is the *System Turn On Time* and is the time to enter the Power-On Default state from Software Reset, No Power, or Power down. Time t0 is maximum 15ms. This time only needs to be done once, upon transitioning from either a No Power or Power Down state, or whenever a reset is issued, which should not be done unless the intent is to have the device to go through its entire boot sequence (see the specification System Turn On Time in both Table 8 and Table 9).

The times t1, t2 and t4, are defined as the time it takes from issuing the enabling-sensor command (when the corresponding sensor is off) to DRDY(INT2) going high (data being present) or STATUSINT.bit0 is set to 1.

The time t5 is the time it takes to have the internal filtered data to output the correct representation of the inertial state. t5 is variable and is associated with the user selected Output Data Rate (ODR). We have defined minimum t5 = (3/ODR) to generally represent that time.

t6 is the time it takes to go from a sensor powered state to a state where the sensors are off. This time depends on the Output Data Rate (ODR) and ranges from 1/ODR to 2/ODR.

t7 is the transition time between various states where the sensors are off.

The Gyro Turn on Time (see Table 9) is comprised of t1 (the gyroscope wakeup time) and t5 (the part's filter settling time). t1 is typically 150 ms and t5 is defined as 3/ODR, where ODR is the output data rate in Hertz.

The Accel Turn on Time (see Table 8) is comprised of t2 (the accelerometer wakeup time) and t5 (the part's filter settling time). t2 is typically 3 ms, and t5 is defined as 3/ODR, where ODR is the output data rate in Hertz.

The t7 transition is dependent on data transfer rates and is for I2C at 400 kHz is <100 μs for SPI at 11 Mbps is around 40 μs.

### 7.4 Chip Reset Process

There are two approaches that can trigger the QMI8658A to run the Reset process, Power-On Reset and Software Reset.

Power-On reset is initialized by driving the VDD & VDDIO lines to valid working range from the Power Off status (VDD = 0V, VDDIO = 0V). Refer to 3.2 for details. The Power-On Reset process starts from the release of POR, refer to 3.3 for details.

The Software Reset (Soft Reset) is generated by writing the 0xB0 to RESET register (0x60). Refer to 5.9. After the Reset is triggered (Power-On Reset and Software Reset), the QMI8658 will run the reset process. The UI registers, internal RAM, FIFO will be set to default values, Analog and digital circuitries will be disabled, refer to 3.3 for details.

It takes maximum 15ms for the Reset process to be finished. Refer to *Table 8* and *Table 9* for details. Note that the VDDIO & VDD power lines are expected to be stable (no sharp pulse) once settled to the Final Value(s), before the System Turn On Time. Otherwise, the QMI8658A initialization may be interfered by the unwanted power pulse, and result in failure of accelerometer or gyroscope startup, refer to 3.3 for details.

The register 0x4D will present 0x80 if there is a successful Reset (Power-on Reset or Soft Reset) process. Refer to 5.9. Note that the content of register 0x4D could be overwritten after later operations, like enabling the sensor(s) (in CTRL7.bit[1:0]) or implementing the CTRL9 command, so host is expected to read the register immediately after POR or Software Reset to check the Reset result.



## 8. FIFO Description

#### 8.1 FIFO Structure

The QMI8658A contains a programmable 1536-byte FIFO. The FIFO's operating mode and configuration are set via the FIFO\_CTRL register, refer to *Table 24*. FIFO data may consist of gyroscope and accelerometer data and is accessible via the serial interfaces (SPI/I2C/I3C), in burst reads. Depending on how many sensors are enabled, the host is expected to read increments of 6, 12 bytes, corresponding to one and two sensors active at the same time. This feature helps reduce overall system power consumption by enabling the host processor to read and process the sensor data in bursts and then enter a low-power mode. The interrupt function may be used to alert host when FIFO watermark level is reached.



Figure 17. FIFO Data Flow

#### 8.2 FIFO Size

There are four levels of FIFO size: 16 samples, 32 samples, 64 samples, 128 samples. The sample stands for 6 bytes of accelerometer data or 6 bytes of gyroscope data if one of them is enabled, or 6 bytes of accelerometer and 6 bytes of gyroscope data (total 12 bytes) if both are enabled.

The FIFO size is configured using the FIFO\_CTRL.FIFO\_SIZE[1:0]: 16 samples(0), 32 samples(1), 64 samples(2), 128 samples(3), refer to *Table 24*.

When the FIFO is enabled for two sensors (Accelerometer and Gyroscope), the sensors must be set at the same Output Data Rate (ODR), refer to *Table 23* for CTRL2 and CTRL3 registers.

#### 8.3 Configure FIFO Mode

The FIFO has multiple operating modes: Bypass, FIFO, Stream. The operating modes are set by the FIFO CTRL.FIFO MDOE[1:0] bits in the register, refer to *Table 24*.

Configure the FIFO\_CTRL.FIFO\_MODE to 'FIFO'(1) or 'Stream'(2) mode will enable the FIFO functionality. Configure the FIFO MODE to 'Bypass' (0) mode, will disable the FIFO functionality.

Once FIFO is enabled and the Accelerometer and/or Gyroscope is(are) enabled, the corresponding data will be filled into FIFO.

In 'FIFO' mode, once FIFO is full, the data filling will stop and new data will be discarded until the host reads out the FIFO data and release the space for new data to be written to.

In 'Stream' mode, once FIFO is full, the data filling will continue and the oldest data will be discarded, until host reads out the FIFO data and releases the space for new data to be written to.



#### 8.4 FIFO Sample Count

The FIFO Sample Count indicates the filled content level of FIFO, which means the quantity of sensor data that was written into FIFO, and to be read out.

The FIFO Sample Count is a 10-bit value and stored in FIFO\_SMPL\_CNT and FIFO\_STATUS[1:0], unit is word(two bytes). Host need to read the two registers, to calculate the number of bytes of FIFO content data by below formular:

FIFO\_Sample\_Count (in byte) = 2 \* (fifo\_smpl\_cnt\_msb[1:0] \* 256 + fifo\_smpl\_cnt\_lsb[7:0])

#### 8.5 FIFO Watermark Interrupt

The FIFO\_WTM register(0x13) indicates the expected level of FIFO data that host wants to get the FIFO Watermark interrupt. The unit is sample, which means 6 bytes if one of accelerometer and gyroscope is enabled, and 12 bytes if both are enabled.

Note that the configured FIFO watermark should not be higher than the FIFO size configured by FIFO\_CTRL.FIFO\_SIZE.

If the FIFO\_WTM is written with non-zero value, the FIFO watermark function is enabled. The internal FIFO watermark interrupt will be triggered if the FIFO content level reaches or is higher than the configured FIFO watermark level. The FIFO\_STATUS.FIFO\_WTM flag will be set to 1, and will be cleared to 0 if FIFO content drops lower than the FIFO watermark level.

The internal FIFO watermark interrupt signal can drive the INT1 pin if CTRL1.bit2 = 1, or INT2 pin if CTRL1.bit2 = 0. Note that the CTRL1.bit3(INT1) and CTRL1.bit4(INT2) controls the high-Z or push-pull mode of the INT pins, refer to 6 *Interrupts* for details.

Once the corresponding INT pin is configured to the push-pull mode, the FIFO watermark interrupt can be seen on the corresponds INT pin. It will keep high level as long as the FIFO filled level is equal to or higher than the watermark, will drop to low level as long as the FIFO filled level is lower than the configured FIFO watermark after reading out by host and FIFO\_RD\_MODE is cleared.

#### 8.6 FIFO Full

The FIFO\_STATUS.FIFO\_FULL flag is set if the FIFO filled level (samples) equals to the FIFO size configured by FIFO CTRL.FIFO SIZE, and is cleared if FIFO filled level is lower than the FIFO size.

#### 8.7 FIFO Read Mode

To read out the FIFO data, host need to set the FIFO into Read Mode, by issuing CTRL\_CMD\_REQ\_FIFO command through CTRL9 process, refer to 5.10 CTRL 9 Functionality (Executing Pre-defined Commands).

Once FIFO Read Mode is enabled, FIFO data will be directed to the FIFO\_DATA register, then host can possibly read data from the FIFO\_DATA register.

Note that once FIFO Read Mode is enabled, the new data won't be filled into FIFO, and will be discarded. Host is expected to read out the FIFO data and disable the FIFO Read Mode before the new data come. Otherwise, data dropping will happen. The time for the new data come is defined by the sensor ODR, which is 1 / ODR.

#### 8.8 Read FIFO Data

The FIFO data is read through the I<sup>2</sup>C/I<sup>3</sup>C/SPI interface by reading the FIFO\_DATA register. Any time the FIFO\_DATA register is read, data is erased from the FIFO memory, corresponds to First-In-First-Out concept.

Host is expected to read out the FIFO data, following below sequence:

- (1) Got FIFO watermark interrupt by INT pin or polling the FIFO\_STATUS register (FIFO\_WTM and/or FIFO\_FULL).
- (2) Read the FIFO\_SMPL\_CNT and FIFO\_STATUS registers, to calculate the level of FIFO content data, refer to 8.4 FIFO Sample Count.
- (3) Send CTRL\_CMD\_REQ\_FIFO (0x05) by CTRL9 command, to enable FIFO read mode. Refer to CTRL\_CMD\_REQ\_FIFO for details.
- (4) Read from the FIFO DATA register per FIFO Sample Count.
- (5) Disable the FIFO Read Mode by setting FIFO\_CTRL.FIFO\_rd\_mode to 0. New data will be filled into FIFO afterwards.



### 8.9 FIFO Data Pattern

Note that when only the accelerometer or gyroscope is enabled, the sensor data format at the host interface is:

or

 ${\sf GX\_L[0]} \ {\sf gGX\_H[0]} \ {\sf gGY\_L[0]} \ {\sf gGY\_H[0]} \ {\sf gGZ\_L[0]} \ {\sf gGZ\_H[0]} \ {\sf gGX\_L[1]} \ {\sf g...}$ 

When both accelerometer and gyroscope are enabled, the sensor data format is:

AX\_L[0] gAX\_H[0] gAY\_L[0] gAY\_H[0] gAZ\_L[0] gAZ\_H[0] g

 $GX_L[0] gGX_H[0] gGY_L[0] gGY_H[0] gGZ_L[0] gGZ_H[0] g$ 

AX\_L[1] gAX\_H[1] g...

### 8.10 Reset FIFO

The FIFO content can be cleared/emptied by inserting CTRL\_CMD\_RST\_FIFO through CTRL9 process, refer to 5.10 CTRL 9 Functionality (Executing Pre-defined Commands) for details.



### 9. Motion Detection

The calculation of the Motion Detection (No-, Any-, or Significant-Motion) is based on the accelerometer ODR defined by CTRL2.aODR, refer to Table 23 for details.

The Motion Detection can only work in Non-Sync Sample mode, refer to *6.2 Non-SyncSample mode* for details. No-, Any-, or Significant-Motion interrupts can be issued to host. No-Motion interrupt indicates that the device is in idle/quiet status, host can run into sleep or low-power mode. Any-Motion interrupt indicates that the device is in movement, host can be awakened from sleep/low-power mode. Significant-Motion indicates host that the device is in significant and continuous movement.

#### 9.1 Motion Detection Principle

Any-/No-/Significant-Motion detection is calculating on the slope of the acceleration of enabled axis:

Slope(n) = Acc(n) - Acc(n-1), for enabled axis/axes of accelerometer

#### 9.1.1 Any-Motion Detection Principle

Any-Motion Detection is detecting the absolute of slope that is higher than defined threshold (*AnyMotionXThr*, *AnyMotionYThr*, *AnyMotionZThr*), and last consecutively for *AnyMotionWindow* or more samples. As shown in *Figure 18*. If the conditions (threshold and duration) are fulfilled, Any-Motion event flag is set, and can be configured to drive the interrupt pin (INT1 or INT2), synced to the DRDY. When the slope falls within the range of (*-Threshold*, *+Threshold*), the Any-Motion conditions are not fulfilled, and the corresponding interrupt is reset.



Figure 18. Any-Motion Detection Interrupt

#### 9.1.2 No-Motion Detection Principle

No-Motion Detection is detecting the absolute of slope that is lower than defined threshold (NoMotionXThr, NoMotionYThr, NoMotionZThr), and last consecutively for NoMotionWindow or more samples. As shown in Figure 19. If the conditions (threshold and duration) are fulfilled, No-Motion event flag is set, and can be configured to drive the interrupt pin (INT1 or INT2), synced to the DRDY. When the slope falls out of the range of (-Threshold, +Threshold), the No-Motion conditions are not fulfilled, and the corresponding interrupt is reset.





Figure 19. No-Motion interrupt detection

#### 9.1.3 Significant-Motion Detection Principle

Significant-Motion Detection works based on Any-Motion and No-Motion events, so both Any-Motion and No-Motion should be configured and enabled to make sure Significant-Motion Detection runs properly. As shown in *Figure 20*.

After valid Any-Motion is detected, if a further Any-Motion is detected after *SigMotionWaitWindow* and before the *SigMotionConfirmWindow* time, the Significant-Motion event flag will be raised to the interrupt path. The Significant-Motion interrupt is cleared when No-Motion is detected.



Figure 20. Significant-Motion interrupt detection



#### 9.2 Motion Detection Flow

The flow chart of No-Motion Detection is show in Figure 21

No-Motion Detection Flow.

The flow chart of Any-Motion Detection is show in Figure 22 Any-Motion Detection Flow.

The flow chart of Significant-Motion Detection is show in Figure 23 Significant-Motion Detection Flow.



Figure 21. No-Motion Detection Flow



Figure 22. Any-Motion Detection Flow



Figure 23. Significant-Motion Detection Flow



### 9.3 Parameters of Motion Detection

**Table 33. Motion Detection Parameters** 

| Parameter Name                                  | Format                                        | Resolution           | Description                                                                                                                                                     |
|-------------------------------------------------|-----------------------------------------------|----------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| NoMotionAxisLogic                               | 1-bit integer                                 | 1                    | O: Logic-OR between events of enabled axes for No-Motion detection     1: Logic-AND between events of enabled axes for No-Motion detection                      |
| NoMotionEnX<br>NoMotionEnY<br>NoMotionEnZ       | 1-bit integer                                 | 1                    | the corresponding axis is not involved for calculation     the corresponding axis data is calculated for No-Motion detection                                    |
| NoMotionXThr<br>NoMotionYThr<br>NoMotionZThr    | 1-byte format<br>unsigned, 5-bits<br>fraction | 0.03125g<br>(1 / 32) | Defines the slope threshold of the corresponding axis for No-Motion detection                                                                                   |
| NoMotionWindow                                  | 1-byte integer                                | 1 sample             | Defines the minimum number of consecutive samples (duration) that the absolute of the slope of the enabled axis/axes data should keep lower than the threshold  |
| AnyMotionAxisLogic                              | 1-bit integer                                 | 1                    | D: Logic-OR between events of enabled axes for Any-Motion detection     Logic-AND between events of enabled axes for Any-Motion detection                       |
| AnyMotionEnX<br>AnyMotionEnY<br>AnyMotionEnZ    | 1-bit integer                                 | 1                    | 0: the corresponding axis is not involved for calculation     1: the corresponding axis data is calculated for Any-Motion detection                             |
| AnyMotionXThr<br>AnyMotionYThr<br>AnyMotionZThr | 1-byte format<br>unsigned,<br>5-bits fraction | 0.03125g<br>(1 / 32) | Defines the slope threshold of the corresponding axis for Any-Motion detection                                                                                  |
| AnyMotionWindow                                 | 1-byte format unsigned, 5-bits fraction       |                      | Defines the minimum number of consecutive samples (duration) that the absolute of the slope of the enabled axis/axes data should keep higher than the threshold |
| SigMotionWaitWind<br>ow                         | 2-bytes integer                               | 1 sample             | Defines the wait window (idle time) starts from the first Any-Motion event until starting to detecting another Any-Motion event for confirmation                |
| SigMotionConfirmW indow                         | 2-bytes integer                               | 1 sample             | Defines the maximum duration for detecting the other Any-Motion event to confirm Significant-Motion, starts from the first Any-Motion event                     |

**Note**: Once the Logic-OR is selected, the calculation on any enabled axis and reported one valid event, will trigger the corresponding Motion Detection (Any-Motion or No-Motion). Once the Logic-AND is selected, the calculation on all enabled axes should report valid event, to trigger the corresponding Motion Detection (Any-Motion or No-Motion).

The MOTION\_MODE\_CTRL byte consists of the parameters shown in Table 34.

### Table 34. MOTION\_MODE\_CTRL Content

| 7                 | 6           | 5           | 4           | 3                  | 2            | 1            | 0            |
|-------------------|-------------|-------------|-------------|--------------------|--------------|--------------|--------------|
| NoMotionAxisLogic | NoMotionEnZ | NoMotionEnY | NoMotionEnX | AnyMotionAxisLogic | AnyMotionEnZ | AnyMotionEnY | AnyMotionEnX |
|                   |             |             |             |                    |              |              |              |



### 9.4 Config Motion Detection

The Motion Detection parameters are divided into two sets and can be passed to the QMI8658A internal algorithm through two callings of CTRL9 command. As shown in *Table 35*.

Host should write the parameters to the corresponding registers, according to *Table 35*. Especially, write 0x01 to CAL4\_H register for the first set of parameters, while write 0x02 to CAL4\_H for the second set of parameters. Refer to *Table 30* for address of CAL registers.

Then trigger the CTRL9 command with 0x0E(CTRL\_CMD\_CONFIGURE\_MOTION). Refer to Table 29 for details.

Table 35. Write Motion Detection Parameters to QMI8658A

| Register (bits) | First CTRL9 Command             | Second CTRL9 Command            |
|-----------------|---------------------------------|---------------------------------|
| CAL1_L (7:0)    | AnyMotionXThr.                  | AnyMotionWindow.                |
| CAL1_H (7:0)    | AnyMotionYThr.                  | NoMotionWindow                  |
| CAL2_L (7:0)    | AnyMotionZThr.                  | SigMotionWaitWindow[7:0]        |
| CAL2_H (7:0)    | NoMotionXThr.                   | SigMotionWaitWindow [15:8]      |
| CAL3_L (7:0)    | NoMotionYThr.                   | SigMotionConfirmWindow[7:0]     |
| CAL3_H (7:0)    | NoMotionZThr.                   | SigMotionConfirmWindow[15:8]    |
| CAL4_L (7:0)    | MOTION_MODE_CTRL                | NA                              |
| CAL4_H (7:4)    | 0x01(means 1st command)         | 0x02(means 2nd command)         |
| CTRL9 code      | 0x0E(CTRL_CMD_CONFIGURE_MOTION) | 0x0E(CTRL_CMD_CONFIGURE_MOTION) |

Note: Configuration should be done when accelerometer and gyroscope are disabled (CTRL7.aEN = CTRL7.gEN =0).

#### 9.5 Enabling Motion Detection

After successfully passing the parameters to QMI8658A Motion Detection engine, host need to enable the Any-Motion Detection engine by setting CTRL8.bit1 to 1, enable the No-Motion Detection engine by setting CTRL8.bit2 to 1, enable the Significant-Motion Detection engine by setting CTRL8.bit3 to 1. If the accelerometer is configured and enabled too, the enabled engines will be started to detect the corresponding events.

On contrary, set the bit(s) in CTRL8.bit[3:1] to 0, will disable the corresponding engine. This can be done when accelerometer and/or gyroscope are(is) enabled or disabled. Refer to 5.3 Configuration Registers for the details of CTRL8.

#### 9.6 Motion Interrupt

Once the Any-Motion, No-Motion and/or Significant-Motion event(s) is/are reported, the corresponding Motion Detection Event will be generated.

The Motion Event (internal signal) can be selected to drive INT1(CTRL8.bit6 = 1) or INT2(CTRL8.bit6 = 0). And once the corresponding INT pin is enabled (by CTRL1.bit3 for INT1, or CTRL1.bit4 for INT2), the Motion interrupt can be seen on the INT pin (synced with DRDY). Refer to 5.3 Configuration Registers for details.

At the meantime, the STATUS1.bit[7:5] is updated and host can read these bits to confirm the Motion interrupt status. Note that the STATUS1.bit[5] = 1 represents the Any-Motion was detected, STATUS1.bit[6] = 1 represents the No-Motion was detected, STATUS1.bit[7] = 1 represents the Significant-Motion was detected. Refer to 5.3 Configuration Registers for details.



## 10. Tap

The Tap engine detects the Single-Tap or Double-Tap, if enabled.

The calculation of the Tap Detection is based on the accelerometer ODR defined by CTRL2.aODR, refer to Table 23 for details.

The Tap detection can only work in Non-SyncSample mode, refer to for details 6.2 Non-SyncSample mode.

### 10.1 Tap Detection Principle

Figure 24 shows the principle of Tap detecting, includes Single Tap and Double Tap.

The acceleration data of the three axes (x, y, z) is dynamically averaged to get the Average of Acceleration. Alpha parameter defines the ratio/weight of the averaging calculation.

The Linear Acceleration is calculated: Linear Acceleration = Acceleration - Average of Acceleration.

The Average Movement Magnitude indicates the movement energy level, is used to detect the Quiet status. It is calculated with *Gamma* 

If the square sum of the Linear Acceleration of three axes is higher than the *PeakMagThr*, the peak detecting is started. If later at the end of *PeakWindow*, the Average of the Movement Magnitude is lower than the *UDMThr* (*Undefined Motion Threshold*), it means the vibration is low and return to Quiet status, it is considered a valid Peak is detected.

If a valid Peak is detected, and no further significant vibration within the *TapWindow* (be quiet after the Peak, no further Tap), a valid Tap is detected.

Once a valid Tap (first Tap) is detected, the second Tap of the Double-Tap should be detected after the TapWindow (Quiet time after first Tap) and before the *DTapWindow* (timeout of the Double Tap detection), and the Double-Tap event will be reported.

If the second Tap is detected within the *TapWindow*, it is considered as the Undefined Motion, and will reset the full Tap process, no Tap event will be reported.

If no further Tap is detected within the *DTapWindow*, Single-Tap event will be reported. The Tap detected after *DTapWindow*, is considered as the First Tap of the new round of detecting.



Figure 24. Tap Detect Principle



## **10.2 Tap Detection Parameters**

The parameters listed in *Table 36* are used to configure the Tap Engine.

**Table 36. Tap Parameters** 

| Parameter Name | Format                   | Resolution          | Description                                                                                                                                                                                                                                                                                                                                                                |
|----------------|--------------------------|---------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                |                          |                     | Priority definition between the x, y, z axes of acceleration. Only Priority[2:0] bits are used.                                                                                                                                                                                                                                                                            |
| Priority       | 1-byte integer           | NA                  | The axis that output the first peak of Linear Acceleration in a valid Tap detection, will be consider as the Tap axis. However, there is possibility that two or three of the axes shows same Linear Acceleration at exactly same time when reach (or be higher than) the PeakMagThr. In this case, the defined priority is used to judge and select the axis as Tap axis. |
| PeakWindow     | 1-byte integer 1 sample  |                     | Defines the maximum duration (in sample) for a valid peak. In a valid peak, the linear acceleration should reach or be higher than the <i>PeakMagThr</i> and should return to quiet (no significant movement) within <i>UDMThr</i> , at the end of <i>PeakWindow</i> .  E.g., 20 @500Hz ODR                                                                                |
|                |                          |                     |                                                                                                                                                                                                                                                                                                                                                                            |
| TapWindow      | 2-bytes integer          | 1 sample            | Defines the minimum quiet time before the second Tap happens. After the first Tap is detected, there should be no significant movement (defined by <i>UDMThr</i> ) during the <i>TapWindow</i> . The valid second tap should be detected after <i>TapWindow</i> and before <i>DTapWindow</i> .                                                                             |
|                |                          |                     | E.g., 50 @500Hz ODR                                                                                                                                                                                                                                                                                                                                                        |
| DTapWindow     | 2-bytes integer 1 sample |                     | Defines the maximum time for a valid second Tap for Double Tap, count start from the first peak of the valid first Tap.                                                                                                                                                                                                                                                    |
|                |                          |                     | E.g., 250 @500Hz ODR                                                                                                                                                                                                                                                                                                                                                       |
| Alpha          | 1-byte unsigned,         | 0.0078              | Defines the ratio for calculation the average of the acceleration. The bigger of <i>Alpha</i> , the bigger weight of the latest data.                                                                                                                                                                                                                                      |
| '              | 7-bits fraction          | (1/128)             | E.g., 0.0625                                                                                                                                                                                                                                                                                                                                                               |
| Gamma          | 1-byte unsigned,         |                     | Defines the ratio for calculating the average of the movement magnitude. The bigger <i>Gamma</i> , the bigger weight of the latest data.                                                                                                                                                                                                                                   |
|                | 7-bits fraction          | (1/128)             | E.g., 0.25                                                                                                                                                                                                                                                                                                                                                                 |
| PeakMagThr     | 2-bytes<br>unsigned,     | 0.001g <sup>2</sup> | Threshold for peak detection.                                                                                                                                                                                                                                                                                                                                              |
| . camagiii     | 10-bits fraction         | (1/ 1024)           | E.g, 0.8g <sup>2</sup> (0x0320)                                                                                                                                                                                                                                                                                                                                            |
| UDMThr         | 2-bytes<br>unsigned,     | 0.001g              | Undefined Motion threshold. This defines the threshold of the Linear Acceleration for quiet status.                                                                                                                                                                                                                                                                        |
|                | 10-bits fraction         | (1/ 1024)           | E.g., 0.4g <sup>2</sup> (0x0190)                                                                                                                                                                                                                                                                                                                                           |
|                |                          |                     |                                                                                                                                                                                                                                                                                                                                                                            |



The Priority[2:0] is defined as below:

0: (X > Y > Z)

1: (X > Z > Y)

2: (Y > X > Z)

3: (Y > Z > X)

4: (Z > X > Y)

5: (Z > Y > X)

6, 7: (Same as 0)

### 10.3 Configure Tap

The Tap parameters are divided into two sets and can be passed to the QMI8658A internal algorithm through two callings of CTRL9 command. As shown in *Table 37*.

Host should write the parameters to the corresponding registers, according to *Table 37*. Especially, write 0x01 to CAL4\_H register for the first set of parameters, while write 0x02 to CAL4\_H for the second set of parameters. Refer to *Table 30* for address of CAL registers.

Then trigger the CTRL9 comment with 0x0C(CTRL\_CMD\_CONFIGURE\_TAP). Refer to 5.10 for details.

Table 37. Write Tap Parameters to QMI8658A

| Register (bits) | First Command Set                           | Second Command Set           |
|-----------------|---------------------------------------------|------------------------------|
| CAL1_L (7:0)    | PeakWindow[7:0]                             | Alpha[7:0]                   |
| CAL1_H (7:0)    | Priority[7:0] (actually only [2:0] is used) | Gamma[7:0]                   |
| CAL2_L (7:0)    | TapWindow[7:0]                              | PeakMagThr[7:0]              |
| CAL2_H (7:0)    | TapWindow[15:8]                             | PeakMagThr[15:8]             |
| CAL3_L (7:0)    | DTapWindow[7:0]                             | UDMThr[7:0]                  |
| CAL3_H (7:0)    | DTapWindow[15:8]                            | UDMThr[15:8]                 |
| CAL4_L (7:0)    | NA                                          | NA                           |
| CAL4_H (7:4)    | 0x01(means 1st command)                     | 0x02(means 2nd command)      |
| CTRL9 code      | 0x0C(CTRL_CMD_CONFIGURE_TAP)                | 0x0C(CTRL_CMD_CONFIGURE_TAP) |

Note: Configuration should be done when accelerometer and gyroscope are disabled(CTRL7.aEN = CTRL7.gEN =0).

### 10.4 Enable Tap Detection

After successfully passing the parameters to QMI8658A Tap engine, host need to enable the Tap engine by setting CTRL8.bit0 to 1. If the accelerometer is properly configured and enabled (CTRL7.aEN = 1), Tap engine will be started to detect the taps. To detect the Tap activity, it is recommended to set accelerometer ODR to higher than 200Hz (defined by CTRL2.aODR).

If CTRL8.bit0 is set to 0, or CTRL7.aEN = 0, the Tap engine will be stopped to detect the taps.

#### 10.5 Tap Interrupt

Once the Tap event is reported (Single- or Double-Tap), it can generate the Tap interrupt.

The Tap event (internal signal) can be selected to drive INT1(CTRL8.bit6 = 1) or INT2(CTRL8.bit6 = 0). And once the corresponding INT pin is enabled (by CTRL1.bit3 for INT1, or CTRL1.bit4 for INT2), the Tap interrupt will be seen on the INT pin (synced with DRDY). Refer to to 5.3 Configuration Registers for details.



At the meantime, the STATUS1.bit1 is set and host can read this bit to confirm the Tap (Single- or Double-Tap) interrupt is generated.

### 10.6 Tap Detection Output

When the Tap (Single- or Double-Tap) is detected, the information of the Tap is presented in TAP\_STATUS (register 0x59). The TAP\_STATUS is updated and valid after the Tap event is detected (STATUSINT.bit1 = 1).

The TAP\_NUM indicate the Single-Tap (TAP\_STATUS.TAP\_NUM = 1) or Double-Tap (TAP\_STATUS.TAP\_NUM = 2) was detected.

The TAP\_STATUS.TAP\_AXIS indicates the first valid peak of the Tap happens on X axis (TAP\_STATUS.TAP\_AXIS = 1), or Y axis (TAP\_STATUS.TAP\_AXIS = 2), or Z axis (TAP\_STATUS.TAP\_AXIS = 3). Note the TAP\_AXIS judgement follows the definition of the Tap Priority. Refer to *Table 36* for details.

The TAP\_STATUS.TAP\_POLARITY indicates the direction from which the Tap moves towards QMI8658A. Note that, this direction is derived from the value of the linear acceleration of first valid Peak.



# 11. Locking Mechanism

## 11.1 Locking Mechanism Principle

The Locking Mechanism function is enabled in SyncSample mode, can lock the sensor data and keep the values in data registers after a proper locking process.

As the concept of "shadow register", which enables host to read the locked data in unlimited delay without the risk of mixing the two consecutive data if the new data comes and updates to the sensor data registers during the host read the sensor data registers. Refer to 6.1 SyncSample mode.

### 11.2 Locking Mechanism Data Reading Process

Figure 25 shows the process of reading data in Locking Mechanism.



Figure 25. Data Reading Process in Locking Mechanism



#### 11.2.1 Disable/Enable AHB Clock Gating

First host need to disable the internal AHB clock gating, this will fully screen out the possibility of misalignment of the two consecutive data samples. Note this is ONLY needed when using SPI (accel only mode with ODR less than 500Hz), I2C or I3C interfaces (in all ODRs).

Host can disable the internal AHB clock gating by applying:

- (1) write 0x01 to CAL1\_L register.
- (2) write 0x12 (CTRL\_CMD\_AHB\_CLOCK\_GATING) in CTRL9 protocol, refer to 5.9 and 5.10.6.10.

After disabling the sensor, enable back the clock gating by:

- (1) write 0x00 to CAL1\_L register.
- (2) write 0x12 (CTRL\_CMD\_AHB\_CLOCK\_GATING) in CTRL9 protocol, refer to 5.9 and 5.10.6.10.

#### 11.2.2 Enable Locking Mechanism

The locking Mechanism is enabled when setting CTRL7.bit7 to "1" (syncSmpl) and enable accelerometer and/or gyroscope.

- (1) Enable 6DOF in this mode, write 0x83 to CTRL7.
- (2) Enable only Accel in this mode, write 0x81 to CTRL7.
- (3) Enable only Gyro in this mode, write 0x82 to CTRL7.

#### 11.2.3 Reading Sensor Data

When the Locking Mechanism is enabled, the reading to the STATUSINT register when new sensor data is available (STATUSINT.Avail = 1) will trigger the locking of the current sensor data sample. Once the data sample is locked, new data will be dropped, until the release of the locking. The Locking Mechanism is automatically released after host reads GZ\_H if gyroscope is enabled or AZ\_H if accelerometer only is enabled.

Process of data reading in Locking Mechanism mode:

Read STATUSINT register, if STATUSINT.Avail = 1, the locking mechanism is started to take effect, go to step 2. If STATUSINT.Avail = 0, repeat step 1.

If STATUSINT.Avail = 1 and STATUSINT.Locked = 0, means data looking is in progress, and will be locked within Data\_Lock\_Delay. If STATUSINT.Locked = 1, go to step 4.

(1) Wait for Data\_Lock\_Delay duration (refer to 11.3), go to step 4.

Burst read the sensor data until the last byte of enabled sensor(s) (to release the locking), Refer to Table 26.

(2) Repeat step 1 - 4, until Exit

### 11.3 Data\_Lock\_Delay

When the gyroscope is enabled the duration of Data\_Lock\_Delay is shown in Table 38.

Table 38. Data\_Lock\_Delay When Gyroscope Is Enabled

| ODR setting | ODR(Hz) | Data_Lock_Delay (usec) |
|-------------|---------|------------------------|
| 0           | 7174.4  | 2                      |
| 1           | 3587.2  | 2                      |
| 2           | 1793.6  | 4                      |
| 3           | 896.8   | 6                      |
| 4           | 448.4   | 12                     |
| 5           | 224.2   | 12                     |
| 6           | 112.1   | 12                     |
| 7           | 56.05   | 12                     |



| 8 28.025 | 12 |
|----------|----|
|----------|----|

When the gyro is not enabled (accel only mode) the value of Data\_Lock\_Delay is shown in Table 39.

Table 39. Data\_Lock\_Delay When Gyroscope Is Disabled

| ODR setting | ODR(Hz) | Data_Lock_Delay (usec) |
|-------------|---------|------------------------|
| 3           | 1000    | 6                      |
| 4           | 500     | 12                     |
| 5           | 250     | 24                     |
| 6           | 125     | 48                     |
| 7           | 62.5    | 48                     |
| 8           | 31.25   | 48                     |
| 12          | 128     | 40                     |
| 13          | 21      | 100                    |
| 14          | 11      | 200                    |
| 15          | 3       | 270                    |

### 11.4 Exit Locking Mechanism

Once pulling sensor data from QMI8658 is finished, it can be configured to exit the Locking Mechanism mode, by disabling the sensors by setting CTRL7.bit[1:0] to 0, and enabling the AHB Clock Gating (refer to 0).

### 11.5 On-The-Fly ODR Change in Locking Mechanism

The on-the-fly ODR changing is supported, so host can change the ODR of sensor without disable the sensor.

An example sequence of changing ODR without disabling the sensor in locking mechanism is shown below:

- (1) Write CTRL2/CTRL3 to set the ODR's of accelerometer and gyroscope and full scales.
- (2) Write 0x81 / 0x82 / 0x83 to CTRL7.
- (3) Read Sensor Data according 11.2.3.
- (4) Changing ODR on-the-fly:
  - a. Write 0x01/0x02/0x03 to CTRL7(clear the syncSmpl bit).
  - b. Wait 1ms.
  - c. Clear the Locking Mechanism in case the data is still locked from previous ODR by reading GZ\_H if gyroscope is enabled or AZ\_H if accelerometer only is enabled.
  - d. Write CTRL2 / CTRL3 with the new ODR's.
  - e. Write 0x81/0x82/0x83 to CTRL7.
- (5) Start poll and read Sensor Data using the new ODRs based on 11.2.3.

Note that, the new data will be stable in at least 3 samples for filter to settle down, therefore, it is recommended to discard the first several samples at host side.



## 12. Calibration-On-Demand (COD)

### 12.1 COD Principle

The Calibration-On-Demand supports the on-demand calibration of Gyro X and Y axes. Based on the internal integrated functionality, the QMI8658A can calibrate the internal gain of X & Y axes of gyroscope, result in a more precise sensitivity, and a tighter distribution of the X & Y axes sensitivity over QMI8658A chips.

Note that the Z axis of gyroscope is not influenced by COD.

#### **12.2 Run COD**

To run the COD, host need to

- (1) Set CTRL7.aEN = 0 and CTRL7.gEN = 0, to disable the accelerometer and gyroscope.
- (2) Issue the CTRL\_CMD\_ON\_DEMAND\_CALIBRATION (0xA2) by CTRL9 command.
- (3) And wait about 1.5 seconds for QMI8658A to finish the CTRL9 command.
- (4) Read the COD\_STATUS register (0x46) to check the result/status of the COD implementation.

During the process, it is recommended to place the device in quiet, otherwise, the COD might fail and report error.

If succeeds, the recalibrated gain parameters will be applied to the sensor data afterwards. The updated gains are output to the UI registers and can be read by host, refer to 12.3. The recalibrated gain parameters will be lost if a power on reset or soft reset is implemented, QMI8658A will then use the on-chip default gain parameters.

If failed, there is no influence on the operation of gyroscope, QMI8658A will keep using the previous workable parameters (last successful COD parameters or the on-chip default parameters).

#### 12.3 COD Status

If the COD command is successfully implemented, the COD STATUS register will output 0x00 for the indication.

The non-zero value of COD\_STATUS indicates different modes of failure. Refer to 5.7 Calibration-On-Demand (COD) Status Register for details.

### 12.4 Save and Restore the New Gain Parameters

After a successful COD, the new gains with COD correction will be applied to the future data of X and Y axes of Gyroscope. At the meantime, the new parameters are updated to the registers below, for host to read and save.

- (1) Gyro-X gain (16 bits) will be in dVX L and dVX H registers (0x51, 0x52)
- (2) Gyro-Y gain (16 bits) will be in dVY\_L and dVY\_H registers (0x53, 0x54)
- (3) Gyro-Z gain (16 bits) will be in dVZ\_L and dVZ\_H registers (0x55, 0x56)

If the host saved those gain parameters, it is possible to pass them back to the QMI8658A (without invoking again the COD routine), using the CTRL9 command CTRL CMD APPLY GYRO GAINS (0xAA) as follow:

- (1) Disable Accelerometer and Gyroscope by setting CTRL7.aEN = 0 and CTRL7.gEN = 0
- (2) write Gyro-X gain (16 bits) to registers CAL1 L and CAL1 H registers (0x0B, 0x0C)
- (3) write Gyro-Y gain (16 bits) to registers CAL2\_L and CAL2\_H registers (0x0D, 0x0E)
- (4) write Gyro-Z gain (16 bits) to registers CAL3 L and CAL3 H registers (0x0F, 0x10)
- (5) Write 0xAA to CTRL9 and follow CTRL9 protocol.

Once the CTRL9 command is successfully finished, the restored gains will take effects for future data of Gyroscope.

Note that it is always recommended to run the COD from time to time to apply the precise and up-to-date correction of the Gyro-X and Gyro-Y sensitivity. Designer should be careful to restore the out-of-date gain parameters, especially when there is significant change of PCB stress.



## 13. Self-Test (Check-Alive)

#### 13.1 Accelerometer Self-Test

The accelerometer Self-Test (Check-Alive) is used to determine if the accelerometer is functional and working within acceptable parameters.

It is implemented by applying an electrostatic force to actuate each of the three X, Y, and Z axis of the accelerometer. If the accelerometer mechanical structure responds to this input stimulus by sensing at least 200 mg, then the accelerometer can be considered functional.

The accelerometer Self-Test data is available to be read at registers dVX\_L, dVX\_H, dVY\_L, dVY\_H, dVZ\_L and dVZ\_H. The Host can initiate the Self-Test at any time with the following procedure.

Procedure for accelerometer Self-Test:

- (1) Disable the sensors (CTRL7 = 0x00).
- (2) Set proper accelerometer ODR (CTRL2.aODR) and bit CTRL2.aST (bit7) to 1 to trigger the Self-Test.
- (3) Wait for QMI8658A to drive INT2 to High, if INT2 is enabled (CTRL1.bit4 = 1), or STATUSINT.bit0 is set to 1.
- (4) Set CTRL2.aST(bit7) to 0, to clear STATUSINT1.bit0 and/or INT2.
- (5) Check for QMI8658A drives INT2 back to Low, and sets STATUSINT1.bit0 to 0.

Read the Accel Self-Test result:

X channel: dVX\_L and dVX\_H (registers 0x51 and 0x52) Y channel: dVY\_L and dVY\_H (registers 0x53 and 0x54) Z channel: dVZ\_L and dVZ\_H (registers 0x55 and 0x56)

The results are 16-bits in format signed U5.11, resolution 0.5mg (1 / 2^11 g).

If the absolute results of all three axes are higher than 200mg, the accelerometer can be considered functional. Otherwise, the accelerometer cannot be considered functional.

Note that the Self-Test function will automatically set the full-scall to 16g and use the aODR set by user (CTRL2.aODR). At the end of Self-Test, QMI8658A will update CTR2 with the original value user set before starting the Check-Alive) routine.

The typical time for Self-Test (from setting aST to 1, until the rising edge of INT2 if enabled, or STATUSINT.bit0 is set to 1) costs about 25 ODRs:

25ms @ 1KHz ODR 800ms @ 32Hz ODR 2.2s @ 11Hz ODR

### 13.2 Gyroscope Self-Test

The gyroscope Self-Test (Check-Alive) is used to determine if the gyroscope is functional.

It is implemented by applying an electrostatic force to actuate each of the three X, Y, and Z axis of the gyroscope and measures the mechanical response on the corresponding X, Y, and Z axis. If the equivalent magnitude of the gyroscope output is greater than 300dps for each axis, the gyroscope can be considered as functional.

The gyroscope Self-Test data is available to be read at output registers dVX\_L, dVX\_H, dVY\_L, dVY\_H, dVZ\_L & dVZ\_H. The Host can initiate the Self-Test anytime with the following procedure.

Procedure for gyroscope Self-Test:

- (1) Disable the sensors (CTRL7 = 0x00).
- (2) Set the bit gST to 1. (CTRL3.bit7 = 1'b1).
- (3) Wait for QMI8658A to drive INT2 to High, if INT2 is enabled, or STATUSINT.bit0 is set to 1.
- (4) Set CTRL3.aST(bit7) to 0, to clear STATUSINT1.bit0 and/or INT2.
- (5) Check for QMI8658A drives INT2 back to Low, or sets STATUSINT1.bit0 to 0.
- (6) Read the Gyro Self-Test result:

X channel: dVX\_L and dVX\_H (registers 0x51 and 0x52) Y channel: dVY\_L and dVY\_H (registers 0x53 and 0x54) Z channel: dVZ\_L and dVZ\_H (registers 0x55 and 0x56)



Read the 16 bits result in format signed U12.4, resolution is 62.5mdps (1 / 2^4 dps).

If the absolute results of all three axes are higher than 300dps, the gyroscope can be considered functional. Otherwise, the gyroscope cannot be considered functional.

Note that the Self-Test function will automatically set the full-scale (gFS) and ODR (gODR) of CTRL3. At the end of Self-Test, QMI8658A will update CTR3 with the original value user set before starting the Self-Test routine.

The typical time (from writing gST to 1, until the rising edge of INT2 if enabled, or STATUSINT.bit0 set to 1) cost for the Self-Test process is about 400ms.



### 14. Host Serial Interface

QMI8658A Host Serial Interface supports slave interfaces of I<sup>2</sup>C, MIPI I<sup>3</sup>C and SPI. For SPI, it supports both 3-wire and 4-wire modes. The basic timing characteristics for the interface are described below. Through the QMI8658A Host Serial Interface, the host can access, set up and control the QMI8658A UI Registers.

#### 14.1 Address Auto Increment

During burst reads and writes, the target address can be configured in Auto-Increment or Non-Increment, by CTRL1.ADDR AI(bit 6), refer to 5.3.

For example, during burst read (burst write is similar) started from register 0x0B(CAL1 L):

If ADDR\_AI = 0, the register address will not increase, and QMI8658A will output the content of CAL1\_L, CAL1\_L, CAL1\_L ..., as long as host continues the burst read clock.

If ADDR\_AI = 1, the register address will automatically increase, and QMI8658A will output the content of CAL1\_L, CAL1\_H, CAL2\_L ..., as long as host continues the burst read clock.

Note that the default value of ADDR\_AI is 0, so it is recommended to set it to 1 from beginning, in case of burst read/write is required.

Note that, burst writes to Configuration Registers (refer to *Table 23*) are NOT supported. These registers should be written in single cycle mode only.

### 14.2 Serial Peripheral Interface (SPI)

#### 14.2.1 SPI Features

QMI8658A supports both 3-wire and 4-wire modes in the SPI slave interface. The SPI 4-wire mode uses two control lines (CS, SPC) and two data lines (SDI, SDO). The SPI 3-wire mode uses the same control lines and one bi-directional data line (SDIO). The SDI /SDIO pin is used for both 3- and 4-wire modes and is configured based on the mode selected.

SPI transactions can be done in either Mode 0 (CPOL=0, CPHA=0) or Mode 3 (CPOL=1, CPHA=1). The QMI8658A interface automatically detects which mode is in use and configures clocking accordingly.

SPI 3- or 4-wire modes are configured by setting CTRL1.bit7. SPI 3-wire mode is selected when CTRL1.bit7 = 1. The default configuration is SPI 4-wire mode, that CTRL1.bit7 is 0.

Figure 26 shows the SPI address and data formats.

#### **SPI Features**

- (1) Data is latched on the rising edge of the clock
- (2) Data should change on falling edge of clock
- (3) Maximum frequency is 15 MHz
- (4) Data is delivered MSB first
- (5) Support single read/writes and multi cycle (Burst) read/writes.
- (6) NOTE: burst writes to Configuration Registers (refer to Table 23) are NOT supported. These registers should be written in single cycle mode only.
- (7) Supports 7-bit Address format and 8-bit data format.

#### **Address Format**

| M | SB  |    |    |    |    |    |    | LSB |
|---|-----|----|----|----|----|----|----|-----|
| R | ead | A6 | A5 | A4 | A3 | A2 | A1 | A0  |

Read – indicates read (1) or write (0) transaction relative to the SPI master

#### **Data Format**

| MSB |    |    |    |    |    |    | LSB |
|-----|----|----|----|----|----|----|-----|
| D7  | D6 | D5 | D4 | D3 | D2 | D1 | D0  |

Figure 26. SPI Address and Data Format



#### 14.2.2 SPI Interface Connection

In a typical SPI Master and Multi-Slave configuration, the SPI master shares the SPI clock (SPC), the serial data input (SDI), and the Serial Data Output (SDO) with all the connected SPI slave devices. Unique Chip Select (CS) lines connect each SPI slave to the master.



Figure 27. Typical SPI 4-Wire Connection

Figure 27 and Figure 28 show typical multi-slave 4- and 3-wire configurations. The primary difference between the two configurations is that the SDI and SDO lines are replaced by the bi-directional SDIO line. The SDIO line is driven by the master with both address and data when it is configured for write mode. During read mode, the SDIO line is driven by the master with the address, and subsequently driven by the "addressed" slave with data.



Figure 28. Typical SPI 3-Wire Connection



#### 14.2.3 SPI Transaction Protocol

Figure 29 and Figure 30 illustrate the waveforms for both 4-wire and 3-wire SPI read and write transactions. Note that CS is active during the entire transaction.



Figure 29. SPI 4-Wire Single Byte Read and Write (Mode 0 and Mode 3)





Figure 30. SPI 4-Wire Multi-Byte Read and Write Transactions





Figure 31. SPI 3-Wire Single Byte Read and Write Transactions



Figure 32. SPI 3-Wire Multi-Byte Read and Write Transactions



## 14.2.4 SPI Timing Characteristics

The typical operating conditions for the SPI interface are provided in Table 40. Please refer to Table 6 for the  $V_{IL}$ ,  $V_{IH}$ ,  $V_{OL}$ ,  $V_{OH}$  definition to define the rising and falling edge condition of the timing symbols.

VDDIO = 1.8 V, T = 25°C unless otherwise noted.

**Table 40. SPI Interface Timing Characteristics** 

| Symbol                | Parameter                   | Min. | Max. | Unit |
|-----------------------|-----------------------------|------|------|------|
| tspc                  | SPI Clock Cycle             | 66.6 |      | ns   |
| fspc                  | SPI Clock Frequency         |      | 15   | MHz  |
| t <sub>SPC_HIGH</sub> | SPI Clock High Pulse        | 25   |      | ns   |
| tspc_low              | SPI Clock Low Pulse         | 25   |      | ns   |
| tscs                  | CS Setup Time               | 6    |      | ns   |
| th <sub>CS</sub>      | CS Hold Time                | 8    |      | ns   |
| ts <sub>SDI</sub>     | SDI Input Setup Time        | 5    |      | ns   |
| th <sub>SDI</sub>     | SDI Input Hold Time         | 15   |      | ns   |
| tv <sub>sDO</sub>     | SDO Time for Valid Output   |      | 50   | ns   |
| thspo                 | SDO Hold Time for Output    | 9    |      | ns   |
| tdsDO                 | SDO Disable Time for Output |      | 50   | ns   |
| ts <sub>SDIO</sub>    | SDIO Address Setup Time     | 5    |      | ns   |
| thspio                | SDIO Address Hold Time      | 15   |      | ns   |
| tv <sub>SDIO</sub>    | SDIO Time for Valid Data    |      | 50   | ns   |
| tho <sub>SDIO</sub>   | SDIO Hold Time for Output   |      | 50   | ns   |
| tz <sub>SDIO</sub>    | SDIO Time from CS to High Z |      | 50   | ns   |





SPI: Mode 0



SPI : Mode 3
Timing Characteristics for SPI 3- and 4-Wire Interfaces

Figure 33.



### 14.3 I<sup>2</sup>C Interface

### 14.3.1 I<sup>2</sup>C Slave Address Selection

During the slave device selection phase, the  $I^2C$  master supplies the 7-bit  $I^2C$  slave device address to enable the QMI8658A. When SA0 is pulled down externally, the 7-bit device address becomes 0x6B (0b1101011). The 7-bit device address for the QMI8658A is 0x6A (0b1101010) if SA0 is pulled up or left unconnected. Note that internally there is a weak pull-up of  $200K\Omega$ , and this pull-up resistor will be automatically disabled after the detection of  $I^2C$  slave address during the Reset Process, refer to 7.4.

#### 14.3.2 I<sup>2</sup>C Interface Characteristics

Table 41 provides the  $I^2C$  interface timing characteristics while Figure 34 and Figure 35 illustrate the  $I^2C$  timing for both fast and standard modes, respectively. Please refer to Table 6 for the  $V_{IL}$ ,  $V_{IH}$ ,  $V_{OL}$ ,  $V_{OH}$  definition to define the rising and falling edge condition of the timing symbols.

For additional technical details about the  $I^2C$  standard, such as pull-up resistor sizing the user is referred to "UM10204  $I^2C$ -bus specification and user manual," published by NXP B.V.

Table 41. I<sup>2</sup>C Timing Characteristics

| Symbol                               | Parameter                                                           | Conditions    | Min.     | Тур.                               | Max. | Unit |
|--------------------------------------|---------------------------------------------------------------------|---------------|----------|------------------------------------|------|------|
| fscL                                 | SCL Clock Frequency                                                 |               | 0        |                                    | 400  | KHz  |
| t <sub>BUF</sub>                     | Bus-Free Time between STOP and START Conditions                     |               | 1300     |                                    |      | ns   |
| thd;sta                              | START or Repeated START Hold Time                                   |               | 600      |                                    |      | ns   |
| $t_{LOW}$                            | SCL LOW Period                                                      |               | 1300     |                                    |      | ns   |
| t <sub>HIGH</sub>                    | SCL HIGH Period                                                     |               | 600      |                                    |      | ns   |
| tsu;sta                              | Repeated START Setup Time                                           |               | 600      |                                    |      | ns   |
| t <sub>SU;DAT</sub>                  | Data Setup Time                                                     |               | 100      |                                    |      | ns   |
| 4                                    | Data Hold Time                                                      | Standard Mode | 0        |                                    | 3450 | ns   |
| t <sub>HD;DAT</sub>                  |                                                                     | Fast Mode     | 0        |                                    | 900  |      |
|                                      | SCI Rise Time                                                       | Standard Mode |          |                                    | 1000 | ns   |
| t <sub>RCL</sub> , t <sub>R</sub>    | SCL Rise Time                                                       | Fast Mode     | 20 + 0.1 | 1 * C <sub>B</sub> (17)            | 300  |      |
|                                      | SCL Fall Time                                                       | Standard Mode |          |                                    | 300  | no   |
| t <sub>FCL</sub>                     | SCL Fall Time                                                       | Fast Mode     | 20 + 0.1 | 1 * C <sub>B</sub> <sup>(17)</sup> | 300  | ns   |
|                                      | SDA Rise Time.                                                      | Standard Mode |          |                                    | 1000 |      |
| t <sub>RDA</sub> , t <sub>RCL1</sub> | Rise Time of SCL after a Repeated START Condition and after ACK Bit | Fast Mode     | 20 + 0.1 | 1 * C <sub>B</sub> <sup>(17)</sup> | 300  | ns   |
| +                                    | SDA Foll Time                                                       | Standard Mode |          |                                    | 300  | no   |
| t <sub>FDA</sub>                     | SDA Fall Time                                                       | Fast Mode     | 20 + 0.1 | 1 * C <sub>B</sub> <sup>(17)</sup> | 300  | ns   |
| t <sub>SU;STO</sub>                  | Stop Condition Setup Time                                           |               | 600      |                                    |      | ns   |

#### Note:

17. CB is the bus capacitance.





Figure 34. I2C Standard Mode Interface Timing



Note A: First rising edge of SCLH after Repeated Start and after each ACK bit.

Figure 35. I<sup>2</sup>C Fast Mode Interface Timing

### 14.4 I<sup>3</sup>C Interface

The QMI8658A is compliant with the MIPI Alliance Basic Specification for I3C, version 1.0.

Note that HDR, IBI are not supported by QMI8658A.

The PID of 8658A is 0x086E00051000.

MIPI Manufacturer ID(VID) for QST Corp. is 0x0437.

The static address of I<sup>3</sup>C follows the descriptions in I<sup>2</sup>C, refer to 14.3.1.



# 15. Package and Handling

## 15.1 Package Drawing



Figure 36. 14 Pin LGA 2.5 x 3.0 x 0.83 mm Package



## 15.2 Reflow Specification



#### Note:

Figure from JEDEC J-STD-020

| Profile Feature                                           | Pb-Free Assembly Profile |
|-----------------------------------------------------------|--------------------------|
| Temperature Min. (T <sub>smin</sub> )                     | 150°C                    |
| Temperature Max. (T <sub>smax</sub> )                     | 200°C                    |
| Time (ts) from (T <sub>smin</sub> to T <sub>smax</sub> )  | 60-120 seconds           |
| Ramp-up Rate (T <sub>L</sub> to T <sub>P</sub> )          | 3°C/second max.          |
| Liquidous Temperature (T <sub>L</sub> )                   | 217°C                    |
| Time (t <sub>L</sub> ) Maintained above (T <sub>L</sub> ) | 60-150 seconds           |
| Peak Body Package Temperature (T <sub>P</sub> )           | 260°C +0°C / -5°C        |
| Time (t <sub>P</sub> ) within 5°C of 260°C                | 30 seconds               |
| Ramp-down Rate (T <sub>P</sub> to T <sub>L</sub> )        | 6°C/second max.          |
| Time 25°C to Peak Temperature                             | 8 minutes max.           |

Figure 37. Reflow Profile

## 15.3 Storage Specifications

QMI8658A storage specification conforms to IPC/JEDEC J-STD-020D.01 Moisture Sensitivity Level (MSL) 3. Floor life after opening the moisture-sealed bag is 168 hours with storage conditions: Temperature: ambient to  $\leq$ 30°C and RelativeHumidity: 60%RH.